Git&&GitHub(1)

Git的优势

大部分操作在本地完成,不需要联网
完整性保证
尽可能添加数据而不是删除或修改数据
分支操作非常快捷流畅
与 Linux 命令全面兼容

Git的结构

工作区:提交代码,新建文件;通过git add提交到暂存区
暂存区:临时存储;通过git commit提交到本地库
本地库:存放历史版本

代码托管中心

维护远程库
局域网:GitLab服务器
外网:码云,GitHub

本地库初始化

1,初始化
git init
.git中存放的是本地库的相关的子目录和文件,不能随意修改
带.的都是隐藏文件,查看系统隐藏文件 ls -lA|less
2,设置签名
	形式:tom
	Email:[email protected]
	作用:区分不同开发人员的身份
	辨析:签名与登录远程库的账号信息无关
	命令:
		项目级别/仓库级别,仅在当前本地库有效
			git config user.name tom_pro
			git config user.email [email protected]
			信息保存位置:./.git/config 文件
		系统用户级别
		git config --global user.name tom_glb
		git config --global [email protected]
		信息保存位置:~/.gitconfig 文件
		**优先级(就近原则):项目级别的签名优先于系统用户级别**												
3,基本操作
	git status:查看工作区和暂存区的状态
	git add[file name]:将工作区的“新建/修改” 放到暂存区
	git rm --cached [fileName]:从暂存区删除
	git commit [fileName]:从暂存区提交到本地库
		***未修改不能重复添加***
		在VIM编辑器里面进行修改(安装的时候确定)
		或者是git commit -m+“修改信息”+文件名
			insertions(+):添加的行数
	git reset HEAD 
	git restore --staged 

版本的管理

1,查看日志
git log
Git&&GitHub(1)_第1张图片
git log --pretty=oneline
在这里插入图片描述
git log --oneline
在这里插入图片描述
git reflog
Git&&GitHub(1)_第2张图片
当数据太多的时候,多屏显示操作:
空格向下翻页,b向上翻页,q退出
2,前进与回退
基于索引值操作
git reset --hard +索引值(reflog中的hash值)
使用^符号:只能往后不能向前
git reset --hard HEAD^(一个 ^ 往后退一步)
使用~符号:只能后退
git reset --hard HEAD~n(后退n步)
3,reset命令的三个参数对比
–soft 参数
仅在本地库移动HEAD指针
Git&&GitHub(1)_第3张图片
–mixed 参数
在本地库移动指针
刷新暂存区
Git&&GitHub(1)_第4张图片
–hard参数
在本地库移动指针
刷新暂存区
刷新工作区
4,删除并找回
前提:删除前,文件存在时的状态提交到本地库
操作:git reset --hard[指针位置]
删除操作已经提交到本地库:指针位置指向历史记录
删除操作尚未提交到本地库:指针位置使用HEAD
5,比较文件差异
git diff [文件名]
将工作区中的文件和暂存区进行比较
git diff [本地库中历史版本] [文件名]
将工作区中的文件和本地库历史记录比较
不带文件名比较多个文件

Git分支

分支:在版本控制过程中,使用多条线同时推进多个任务
分支的好处:
	同时并行推进多个功能开发,提高开发效率
	各个分支在开发过程中,如果不做合并,如果某一个分支开发失败,不会对其他分支有任 何影响。失败的分支删除重新开始即可。	
分支操作:
	创建分支:git branch + 分支名
	查看分支:git branch -v 
	切换分支:git checkout +分支名
	合并分支
				切换到接受修改的分支上
					git checkout [被合并分支名]
				执行merge
					git merge [有新内容分支名]
	解决冲突	
		第一步:编辑文件,删除特殊符号
		第二步:把文件修改到满意的程度,保存退出
		第三步:git add [文件名]
		第四步:git commit -m "日志信息"
		注意:此时 commit 一定不能带具体文件名		

你可能感兴趣的:(Git,git)