13518219792

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

技能篇:Git的简易教程

本文转载自微信公众号「潜行前行」,作者cscw。转载本文请联系潜行前行公众号。

创新互联建站是网站建设技术企业,为成都企业提供专业的成都网站建设、网站设计,网站设计,网站制作,网站改版等技术服务。拥有十多年丰富建站经验和众多成功案例,为您定制适合企业的网站。十多年品质,值得信赖!

在学校,或许凭借一个人的力量就能负责整个项目的开发到上线。但是在在公司,因为项目的复杂性和紧急性,一个项目的往往是由多个人实现,此时就有一个问题,代码提交和代码合并。git和svn,这篇文章来讲讲git的原理和使用

version版本控制

git的账号配置

 
 
 
 
  1. # git config --global user.name "hello lwl" 
  2. # git config --global user.email lwl@csc.com 
  3. // 查看系统config 
  4. # git config --system --list 
  5. // 查看当前用户(global)配置 
  6. # git config --global  --list 
  7. // 查看当前仓库配置信息 
  8. # git config --local  --list 

创建git仓库

 
 
 
 
  1. // 在当前目录新建一个Git代码库 
  2. # git init 
  3. // 克隆一个项目和它的整个代码历史(版本信息) 
  4. # git clone [git@github.com:cscsss/learnHome.git] 

git的原理

状态转移流程

文件操作命令

查看文件状态

 
 
 
 
  1. // 查看所有文件状态 
  2. # git status 
  3. // 查看指定文件状态 
  4. # git status [fileName] 

添加文件与目录

 
 
 
 
  1. // 添加指定文件到暂存区 
  2. # git add [file1] [file2] ... 
  3. // 添加指定目录到暂存区,包括子目录文件 
  4. # git add [dir] 

移除文件与目录

 
 
 
 
  1. // 将文件从暂存区和工作区中删除 
  2. # git rm  
  3. // 将 fileName 从暂存区删除文件,仍保留在当前工作目录中 
  4. # git rm --cached  

文件提交 git commit

 
 
 
 
  1. // 将暂存区文件提交到本地仓库区,message为说明信息 
  2. # git commit -m [message]  
  3. // 将暂存区的指定文件 fileName 提交到本地仓库 
  4. # git commit [fileName] -m [message]  
  5. // 追加漏提交的暂存区文件。等价 git add . +  git commit -m 'message' 
  6. # git commit --amend -m [message]  

查看文件状态及历史 git log

 
 
 
 
  1. # git log  //查看提交历史 
  2. # git log --oneline //以精简模式显示查看提交历史 
  3. # git log -p  //查看指定文件的提交历史 
  4. # git blame  //以列表方式查看指定文件的提交历史 

git diff 比较差异

 
 
 
 
  1. // 显示暂存区和工作区的全部差异 
  2. # git diff  
  3. // 显示 filepath 路径文件中,工作区与暂存区的差异 
  4. # git diff filePath    
  5. // 显示在工作区 filePath 文件与 HEAD 分支的差异 
  6. # git diff HEAD filePath  
  7. // 显示在工作区的 filePath 文件与某次提交 commitId 的差异 
  8. # git diff commitId filePath  

git reset 代码回退

 
 
 
 
  1. // git reset [--soft | --mixed | --hard] [HEAD] 
  2. // git reset [--soft | --mixed | --hard] [commit] 
  3. # git reset –hard HEAD~3  //会将最新的3次提交全部重置,就像没有提交过一样 
  4. # git reset 003444c77bae2b0874be17b81a829cfb1237d9ce //重置到003444c7 

重置 HEAD 在当前分支到某次 commit 时,工作目录里的新改动和已经 add 到 stage 暂存区的新改动会全都消失。工作目录(workspace)、暂存区(index/stage)及本地仓库(repository)重置成目标 commit 的內容,所以效果看起来等同于清空暂存区和工作区

--soft 模式在重置 HEAD 时,会保留工作目录和暂存区中的内容,并把重置 HEAD 所带来的新的差异放进暂存区,保留工作目录(workspace)和暂存区(index/stage)的内容,只让 repository 中的内容和 reset 节点保持一致,原节点和 reset 节点之间的「差异变动」会放入暂存区中(index/stage)

--mixed 模式图片git reset 如果不加参数,那么默认使用 --mixed 参数。mixed 模式会保留 工作目录(workspace)的內容,但会将暂存区(index/stage) 和 Repository 中的內容重置成 reset 节点一致,因此原节点和 reset 节点之间的「差异变动」会放入工作目录(workspace)

git revert

如果我们想撤销之前的某一版本,但是又想保留 commitId 提交之后的版本

 
 
 
 
  1. # git revert -n commitId 

分支操作命令

新建分支

 
 
 
 
  1. // 基于当前分支新建一个分支,并且切换到新的分支 lwl 
  2. # git checkout -b lwl   
  3. // 基于远程分支 originBranch 并新建分支 csc 
  4. # git checkout -b csc originBranch 
  5. // 新建一个 csc 分支,但是仍停留在原来分支 
  6. # git branch csc  
  7. // 切换到 csc 分支 
  8. # git checkout csc  

git push

 
 
 
 
  1. ~~ 将本地分支的更新全部推送到远程仓库 master 分支 
  2. # git push origin master  
  3. ~~ 删除远程 branchname 分支 
  4. # git push origin -d     

删除分支

 
 
 
 
  1. # git branch -D    
  2. ~~ 删除本地 dev1 分支 
  3. # git branch -D dev1  

分支合并

git-merge 命令是用于从指定的commit(s)合并到当前分支的操作

 
 
 
 
  1. # git merge branchName //当前分支和 branchName 合并 
  2. # git merge -m   //当前分支和 branchName commit及之前的提交合并 
  3. # git merge --abort // 取消合并 

git pull/git fetch

 
 
 
 
  1. ~~ 拉取所有远端的最新代码 
  2. # git fetch --all   
  3. ~~ 拉取远程最新 master 分支代码(指定 master 分支) 
  4. # git fetch origin master  
 
 
 
 
  1. ~~ 拉取远程仓库分支,更新并合并到本地分支 
  2. # git pull   
  3. ~~ 将远程 master 分支合并到当前本地 master 分支 
  4. # git pull origin master  
  5. ~~ 将远程 master 分支合并到当前本地 lwl 分支,冒号后面表示本地分支 
  6. # git pull origin master:lwl  

git rebase 合并

git rebase master 命令会把当前分支 curBranch 里的每个提交(commit)取消掉,并且把它们临时保存为补丁(patch)(这些补丁放到".git/rebase"目录中),然后把 curBranch 分支更新为 master 分支最新提交,最后把保存的这些补丁应用到 curBranch 分支上

在 rebase 的过程中,也许会出现冲突(conflict)。在这种情况,Git会停止rebase并会让你去解决 冲突;在解决完冲突后,用 git add 命令去更新这些内容的索引(index), 然后,你无需执行 git-commit,只要执行git rebase --continue

 
 
 
 
  1. # git rebase branchName // branchName 合并到当前分支 
  2. # git rebase --continue // 解决冲突后继续合并 
  3. # git rebase --abort //取消合并 
  4. # git rebase -i HEAD~2 //合并提交 --- 2表示合并2个。也可以是3... 

如果 git rebase master 之后。需要将当前分支 curBranch的代码移到 master。可以再次使用 git merge。此时合并后 master 的提交是一条线性 commit

git tag

 
 
 
 
  1. # git tag  //基于最新的 commitId 创建 tagName 
  2. # git tag -a   // 基于某次 commitId 创建 tagName 
  3. # git push origin  //推送到远程仓库 
  4. # git push --tags //推送所有标签 
  5.  
  6. # git tag -d  // 删除本地 tag  
  7. # git push origin :refs/tags/ // 删除远程 tag  

欢迎指正文中错误

参考文章


本文题目:技能篇:Git的简易教程
本文URL:http://cdbrznjsb.com/article/djipopj.html

其他资讯

让你的专属顾问为你服务