Git是一个开源的分布式版本控制系统,用以有效、高速的处理从很小到非常大的项目版本管理。Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件,本篇文章重点为大家讲解一下使用git的小技巧。
我们每个人都不时在输入时犯拼写错误,但是如果你使能了 Git 的自动纠错功能,你就能让 Git 自动纠正一些输入错误的子命令。
假如你想用命令 git status
来检查状态,但是你恰巧错误地输入了 git stats
。通常情况下,Git 会告诉你 ‘stats’ 不是个有效的命令:
$ git statsgit: ‘stats’ is not a git command. See ‘git --help’.The most similar command isstatus
为了避免类似情形,只需要在你的 Git 配置中使能自动纠错功能。
$ git config --global help.autocorrect 1
如果你只想对当前的仓库生效,就省略掉选项 --global
。
这个命令会使能自动纠错功能。在相应的 Git 官方文档 中可以看到这个命令的详细说明,但是试着敲一下上面的错误命令会使你对这个设置干了什么有个直观的了解:
$ git statsgit: ‘stats’ is not a git command. See ‘git --help’.On branch masterYour branch is up to date with ‘origin/master’.nothing to commit, working tree clean
在上面的例子中,Git 直接运行了它建议命令的第一个,也就是 git status
,而不是给你展示它所建议的子命令。
需要对提交进行计数的原因有很多。例如,一些开发人员利用提交计数来判断什么时候递增工程构建序号,也有一些开发人员用提交计数来对项目进展取得一个整体上的感观。
对提交进行计数相当简单而且直接,下面就是相应的 Git 命令:
$ git rev-list --count branch-name
在上述命令中,参数 branch-name
必须是一个你当前仓库里的有效分支名。
$ git rev-list –count master32$ git rev-list –count dev34
你的代码仓库不仅对你来说很宝贵,对你所在的组织也一样。通过少数几个惯例你就能使自己的仓库整洁并且保持最新。使用 .gitignore 文件 就是这些最好的惯例之一。通过使用这个文件你可以告诉 Git 不要保存一些不需要记录的文件,如二进制文件、临时文件等等。
当然,你还可以使用 Git 的垃圾回收来进一步优化你的仓库。
$ git gc --prune=now --aggressive
这个命令在你和你的团队经常使用 pull
或者 push
操作的时候很有帮助。
它是一个内部工具,能清理掉你的仓库里没法访问或者说“空悬”的 Git 对象。
大多数时候,删除所有未追踪的文件是安全的。但很多时候也有这么一种场景,你想删掉这些未追踪的文件同时也想做个备份防止以后需要用到。
Git 组合一些 Bash 命令和管道操作,可以让你可以很容易地给那些未追踪的文件创建 zip 压缩包。
$ git ls-files --others --exclude-standard -z |\ xargs -0 tar rvf ~/backup-untracked.zip
上面的命令就生成了一个名字为 backup-untracked.zip
的压缩包文件(当然,在 .gitignore
里面忽略了的文件不会包含在内)。
每个仓库都有一个 .git
文件夹,它是一个特殊的隐藏文件夹。
$ ls -a. … .git
Git 主要通过两个东西来工作:
.git
文件夹的位置)这个文件夹存储了所有参考信息和一些其他的如配置、仓库数据、HEAD 状态、日志等更多诸如此类的重要细节。
一旦你删除了这个文件夹,尽管你的源码没被删,但是类似你的工程历史记录等远程信息就没有了。删除这个文件夹意味着你的工程(至少本地的复制)不再在版本控制的范畴之内了。这也就意味着你没法追踪你的修改;你没法从远程仓拉取或推送到远程仓了。
通常而言,你需要或者应当对你的 .git
文件夹的操作并不多。它是被 Git 管理的,而且大多数时候是一个禁区。然而,在这个文件夹内还是有一些有趣的工件,比如说当前的 HEAD 状态在内的就在其中。
$ cat .git/HEADref: refs/heads/master
它也隐含着对你仓库地描述:
$ cat .git/description
这是一个未命名的仓库;通过编辑文件 ‘description’ 可以给这个仓库命名。
Git 钩子文件夹连同一些钩子文件例子也在这里。参考这些例子你就能知道 Git 钩子能干什么了。当然,你也可以 参考这个 Seth Kenlon 写的 Git 钩子介绍。
有时,你会想要浏览另一个分支下某个文件的内容。这其实用一个简单的 Git 命令就可以实现,甚至都不用切换分支。
设想你有一个命名为 README.md 的文件,并且它在 main
分支上。当前你正工作在一个名为 dev
的分支。
用下面的 Git 命令,在终端上就行。
$ git show main:README.md
一旦你执行这个命令,你就能在你的终端上看到 main
分支上该文件的内容。
用一个简单的命令你就能在 Git 中像专业人士一样搜索了。更有甚者,尽管你不确定你的修改在哪次提交或者哪个分支上,你依然能搜索。
$ git rev-list --all | xargs git grep -F ''
例如,假设你想在你的仓库中搜索字符串 “font-size: 52 px;"
:
$ git rev-list –all | xargs git grep -F ‘font-size: 52 px;’F3022…9e12:HtmlTemplate/style.css: font-size: 52 px;E9211…8244:RR.Web/Content/style/style.css: font-size: 52 px;
网站栏目:分享一下git使用小技巧
URL标题:http://www.csdahua.cn/qtweb/news7/345907.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网