Git 使用技巧

常用配置设置

正确配置你的用户信息

GitHub 通过你的 ~/.gitconfig 文件提供的信息来追踪你的更改。如果你在多台机器上工作且 ~/.gitconfig 未正确配置,你很可能会得到重复的提交和混乱的历史记录。你需要根据你的 GitHub 凭证修改以下行。

复制代码
[user]
	name = 你的姓名
	email = 你的有效邮箱

正确配置你的 difftool 和 mergetool。

difftool 和 mergetool 是 Git 分别在执行差异比较或冲突解决操作时会运行的软件。

复制代码
[difftool "opendiff"]
	cmd = /usr/bin/opendiff \"$LOCAL\" \"$REMOTE\" -merge \"$MERGED\" | cat
[diff]
	tool = opendiff
[merge]
	tool = opendiff

为最常用的命令创建别名。

你会发现每天会多次使用相同的 Git 命令。为最常用的命令创建别名可以每天节省宝贵的时间。

复制代码
[alias]
	st = status
	ci = commit
	br = branch
	co = checkout
	ds = diff --staged
	changes = log -n1 -p --format=fuller
	amend = commit --amend -C HEAD
	undo = clean -f -d
	undoci = reset HEAD~1
	unstage = reset HEAD --
	lg = log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit
	ls = log --pretty=format:\"%C(yellow)%h %C(blue)%ad%C(red)%d %C(reset)%s%C(green) [%cn]\" --decorate --date=short
	lg-full = log --name-status --pretty=fuller

速查表

创建

操作 命令
克隆一个现有仓库 $ git clone ssh://user@domain.com/repo.git
创建一个新的本地仓库 $ git init

本地更改

操作 命令
查看工作目录中已更改的文件 $ git status
查看已跟踪文件的更改内容 $ git diff
将所有当前更改添加到下一次提交 $ git add .
<文件> 中的部分更改添加到下一次提交 $ git add -p <文件>
提交所有已跟踪文件中的本地更改 $ git commit -a
提交之前已暂存的更改 $ git commit
修改最后一次提交(不要修改已发布的提交! $ git commit --amend

提交历史

操作 命令
显示所有提交,从最新的开始 $ git log
显示特定文件随时间的变化 $ git log -p <文件>
查看谁在何时修改了 <文件> 的什么内容 $ git blame <文件>

分支与标签

操作 命令
列出所有现有分支 $ git branch
切换 HEAD 分支 $ git checkout <分支>
基于当前 HEAD 创建新分支 $ git branch <新分支>
基于远程分支创建新的跟踪分支 $ git checkout --track <远程/分支>
删除本地分支 $ git branch -d <分支>
为当前提交打上标签 $ git tag <标签名>

更新与发布

操作 命令
列出所有当前配置的远程仓库 $ git remote -v
显示远程仓库信息 $ git remote show <远程>
添加新的远程仓库,命名为 <远程> $ git remote add <远程> <URL>
<远程> 下载所有更改,但不合并到 HEAD $ git fetch <远程>
下载更改并直接合并/集成到 HEAD $ git pull <远程> <分支>
将本地更改发布到远程仓库 $ git push <远程> <分支>
删除远程仓库上的分支 $ git branch -dr <远程/分支>
发布你的标签 $ git push --tags

合并与变基

操作 命令
<分支> 合并到当前 HEAD $ git merge <分支>
将当前 HEAD 变基到 <分支> 上(不要对已发布的提交进行变基! $ git rebase <分支>
中止变基操作 $ git rebase --abort
解决冲突后继续变基 $ git rebase --continue
使用配置的合并工具解决冲突 $ git mergetool
使用编辑器手动解决冲突,并在解决后标记文件为已解决 $ git add <已解决文件> $ git rm <已解决文件>

撤销操作

操作 命令
丢弃工作目录中的所有本地更改 $ git reset --hard HEAD
丢弃特定文件的本地更改 $ git checkout HEAD <文件>
撤销一个提交(通过生成一个包含相反更改的新提交) $ git revert <提交>
将 HEAD 指针重置到先前的提交,并丢弃自那时起的所有更改 $ git reset --hard <提交>
将 HEAD 指针重置到先前的提交,并将所有更改保留为未暂存的更改 $ git reset <提交>
将 HEAD 指针重置到先前的提交,并保留未提交的本地更改 $ git reset --keep <提交>
相关推荐
奶油松果1 小时前
git amend记录
git
庸俗今天不摸鱼2 小时前
git提交代码失败?本地代码被清空了?git代码丢了怎么办?三步帮你找回来
git
摇滚侠2 小时前
零基础小白自学 Git_Github 教程,Git 命令行操作3,笔记20
笔记·git·github
摇滚侠3 小时前
零基础小白自学 Git_Github 教程,GitLFS ,笔记21
笔记·git·github
lpfasd1233 小时前
Git之外的新选择?PlasticSCM深度对比与平台支持全解析
git
Cx330❀3 小时前
Git 入门指南:从 0 到 1 掌握版本控制
git·ubuntu·gitee·centos·github
爱凤的小光3 小时前
Git自我学习笔记
笔记·git·学习
江米小枣tonylua4 小时前
从神州22极限救援,看懂Git高级玩法
git
Violet_YSWY14 小时前
git stash和backup一样吗
git