Git是分布式版本控制系统,他们的关系是:
Workspace工作区是我们能看到的区域,我们在Workspace工作区修改增加代码;
完成编辑后,我们用git add 将工作区文件添加到Index / Stage暂存区;
然后利用git commit 提交文件到我们自己的Repository仓库区(或本地仓库)或Remote远程仓库。
GitHub 是使用 git 技术的一个代码托管网站,提供基于 Web 的访问界面。是目前最为流行的源代码管理网站。
一、Git基本命令
1、git init 把当前文件夹初始化为默认的git库
2、git add 文件名 向git库中添加一个文件
3、git rm 文件名 从git库中删除一个文件
4、git status 查看当前库中进行的任务
5、git diff 文件名 add前查看工作区和暂存区的差别
6、git commit -m "修改内容" 把修改内容提交上去,用于区别版本
7、git checkout -- 文件名 在add之前把文件恢复到上次交付,在commit之前恢复到暂存区的状态
8、git log [--pretty=oneline] 显示这个库里都干过啥
9、git relog 查看命令历史,以便确定要回到未来的哪个版本
二、git重置
1、git reset
作用:版本回退,将代码恢复到已经提交的某一个版本中。
git reset --hard 版本号 将代码回退到某个指定的版本(版本号只要有前几位即可)
git reset --hard head~1将版本回退到上一次提交
~1:上一次提交
~2:上上次提交
~0:当前提交
当使用了git reset命令后,版本会回退,使用git log只能看到当前版本之前的信息。使用git reflog可以查看所有的版本信息
三、git忽视文件
在仓库中,有些文件是不想被git管理的,比如数据的配置密码、写代码的一些思路等。git可以通过配置从而达到忽视掉一些文件,这样这些文件就可以不用提交了。
在仓库的根目录创建一个.gitignore的文件,文件名是固定的。
将不需要被git管理的文件路径添加到.gitignore中
四、git分支操作
在git中,分支实质上仅仅是一个指针,每次代码提交后,这个分支指针就会向后移动,保证一直指向最后一次提交的的版本。git中使用HEAD指向当前分支
五、创建分支
git branch 分支名称创建分支,分支中的代码,在创建时与当前分支的内容完全相同。
git在第一次提交时,就有了一个叫master的主分支。
git branch dev,创建了一个叫做dev的分支
六、查看分支
git branch可以查看所有的分支,在当前分支的前面会有一个*。在git中,有一个特殊指针HEAD,永远会指向当前分支。
七、切换分支
git checkout 分支名称切换分支 HEAD指针指向了另一个分支
在当前分支的任何操作,都不会影响到其他的分支,除非进行了分支合并。
提交代码时,会生产版本号,当前分支会指向最新的版本号。
八、创建并切换分支
git checkout -b 分支名称 创建并切换分支
切换分支会做两件事情:创建一个新分支、把head指针指向当前的分支
九、删除分支
git branch -d 分支名称 可以删除分支
注意:不能在当前分支删除当前分支,需要切换到其他分支才能删除。
注意:master分支是可以删除的,但是不推荐那么做。
十、合并分支
git merge 分支名称 将其他分支的内容合并到当前分支。
在master分支中执行git merge dev 将dev分支中的代码合并到master分支
对于同一个文件,如果有多个分支需要合并时,容易出现冲突。
合并分支时,如果出现冲突,只能手动处理,再次提交,一般的作法,把自己的代码放到冲突代码的后面即可。
十一、git远程仓库
github与git:git与github没有直接的关系。git是一个版本控制工具。
github是一个代码托管平台,开源社区,是git的一个远程代码仓库。
十二、git clone
作用:克隆远程仓库的代码到本地
git clone [远程仓库地址]
十三、git push
作用:将本地仓库中代码提交到远程仓库
git push 仓库地址 master 在代码提交到远程仓库,注意master分支必须写,不能省略
十四、git pull
作用:将远程的代码下载到本地
通常在push前,需要先pull一次。
十五、git remote
每次push操作都需要带上远程仓库的地址,非常的麻烦,我们可以给仓库地址设置一个别名
十六、git支持多种数据传输协议:
https协议:需要输入用户名和密码
ssh协议:可以配置免密码登录