设为首页 收藏本站
查看: 812|回复: 0

[经验分享] Git 系列之四:Git 进阶功能-转载

[复制链接]

尚未签到

发表于 2018-1-15 06:15:24 | 显示全部楼层 |阅读模式
Git 系列之四:Git 进阶功能
  【TIP】在我们的《Windows 下 Git 配置与使用指南》 中,有介绍大家使用 $ git go 命令。其实,这并非 Git 的原生命令,它是我们自定义的一个 alias(别名),由 $git add、$git commit、$git push 和 $git pull 四个命令组合而成。待熟悉之后,你可以直接使用这些原生命令,或者自定义更适合自己的 alias。

add
  添加新文件到 Git 代码仓库的索引中
  

$ git add filename  

mv
  移动或重命名文件
  

$ git mv old-filename new-filename  

rm
  从工作目录和 Git 代码索引中删除文件
  

$ git rm filename  

status
  查看目前工作目录的代码状态,自上次提交以来的添加、修改和删除等
  

$ git status  

diff
  查看自上次提交以来,本地代码改动的具体情况
  

$ git diff  

commit
  提交修改的代码(只是提交到本地的代码库,不会推送到服务器)
  

$ git commit -am '修改说明'  

  如果觉得刚提交的“修改说明”写得不够好,可输入以下命令调整
  

$ git commit --amend  

push
  将自上次 push 以来的,本地历次 commit,推送到服务器

  结合我们的实际,应该这样写:
  

$ git push origin master:your-id  


  其中,master 是本地的分支名;your-id 填你在服务器上的>
pull
  将别人推送到服务器的代码,拉到你的机器里
  

$ git pull  

log
  查看修改记录,含作者、时间、修改说明等
  

$ git log  

show
  显示具体的代码改动情况


显示最后一次 commit 修改的内容:
  

$ git show  

显示指定 commit 修改的内容:

  【TIP】git log 命令中,每条 commit 会有一长长的字符串,此即 commid>  

$ git show commit-id  

branch
  分支管理


列出所有分支(当前所在分支前会有“*”号):
  

$ git branch  

新建分支:
  

$ git branch 新分支名  

删除分支:
  

$ git branch -d 欲删除的分支名  

  【注意!】不要把 ‘-d’ 写成了 ‘-D’,危险!



  • -d:要求:被删除分支的所有修改,已经合并到当前分支;
  • -D:直接删除,未合并的代码,将被丢弃!
checkout

恢复某个已修改的文件(撤销未提交的修改):
  

$ git checkout file-name  

切换到另外的分支,进行开发:
  

$ git checkout branch-name  

  【注意!】该命令可能伴随大量的文件增删/修改。Windows 下,改动已被占用的文件可能会被拒绝,导致版本库出现严重问题。如果确实要这样做,安全起见,最好先注销一次。


merge
  合并指定分支到当前分支:
  

$ git merge branch-name  

revert
  还原已提交的修改(已经提交过的修改,可以反悔~)


还原最近一次提交的修改:
  

$ git revert HEAD  

还原指定版本的修改:
  

$ git revert commit-id  

stash
  先将未提交的修改暂存起来,接着清除所有改动,使之与没修改时一样。

  若你正在开发功能 A,又需立即去开发功能 B。A 的代码正改到一半,未认真整理,你不想立即提交。此时……请呼叫 stash ~。


它会使你所有未提交的修改瞬间不见了:
  

$ git stash  

它会使刚刚不见了的修改,瞬间又回来了:
  

$ git stash pop  

  【TIP】以上命令皆有更多参数,另有一些 Git 命令我们此处没有介绍。但是,这已足令你使用 Git 时游刃有余,你会觉得,Git 简直是一件神器!:-)

  【TIP】’$ git help’ 与 ‘$ git help 命令名’ 会在你需要的时候,无私地帮助你。:-)


附:git push 失败的解决办法
  假设执行操作:
  

1. 修改代码  
2. git commit
  
3. git push
  

  此时 push 失败(错误提示:! [rejected] master -> master (non-fast-forward) )

  解决办法:
  

$ git pull  

  若成功,则:
  

$ git push origin master:your-id  

  完事。

  若失败(提示:CONFLICT (content): Merge conflict in 文件名),则:

  冲突的文件会有类似下面的代码块:
  

<<<<HEAD  
你修改的代码
  
============
  
其他人修改的代码

  
>>>>>commit>  

  考虑你和他人对代码的修改,更新成合适的内容,并删除 <<<、===、>>> 3行标记符号,保存文件。
  

$ git commit -am "resolve conflict"  
$ git push origin master:your-id
  

  更详细的说明,可以阅读 $git push –help 该文档的 NOTE ABOUT FAST-FORWARDS 一节。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-435191-1-1.html 上篇帖子: VS2012使用Git并连接到osc@git 下篇帖子: 几款Git GUI客户端工具
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表