【博学谷学习记录】超强总结,用心分享|git和github基本使用

  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协议:可以配置免密码登录

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容