利用git查看文件的修改历史:
在AS中打开目标文件,而后点击上面VCS->Git->Show History
git还原某个特定的文件到之前的版本
场景:
对于某个Git控制下的文件进行了修改,但是改的不满意,想退回到改之前的版本。
假定该文件为 src/main/main.c解决方法:
第一步: 在命令行中输入 git log src/main/main.c 得到该文件的commit 历史。 会得到类似下面的界面
第二步: 复制需要回退版本的hash,在此假设我们回退到 d98a0f565804ba639ba46d6e4295d4f787ff2949 ,则复制该序列即可
第三步:checkout 对应版本。格式为 git checkout <hash> <filename>, 在此即为命令行中输入 git checkout d98a0f565804ba639ba46d6e4295d4f787ff2949 src/main/main.c第四步: commit checkout下来的版本。 如: git commit -m "revert to previous version"
git log -3 --stat 显示3次提交的修改了哪些文件
可以在后面加上 ./ 表示在当前路径下,前3次提交的修改了哪些文件
git log
打印出所有的提交记录 显示commit id
git show 548c72f42f51c22dbf2fdf133426e094c59789e4
显示某一次提交的内容 (全部修改内容)
问题一: git add 添加了多余文件怎么撤销添加的操作?
git status 先看一下add 中的文件
git reset HEAD 如果后面什么都不跟的话 就是上一次add 里面的全部撤销了
git reset HEAD XXX/XXX/XXX.java 就是对某个文件进行撤销了
reset只是撤销了添加,文件还是已修改状态,再用checkout命令将作出的修改还原掉。
问题二:
如果不小心弄错了git add后,又git commit了,但是还没有push,怎么办?
git log 查看节点
git reset commit_id (回退到上一个提交的commit_id节点 代码还是原来你修改过后的)
或者git reset –-hard commit_id (回退到上一个提交的commit_id节点, 代码的修改也被清除了)
问题三:
弄错了git add后,又git commit了,又push了,怎么办?
使用 git revert命令
此次操作之前和之后的commit和history都会保留,并且把这次撤销作为一次最新的提交
git revert HEAD 撤销前一次 commit
git revert HEAD^ 撤销前前一次 commit
git revert commit-id (撤销指定的版本,撤销也会作为一次提交进行保存)
git revert是提交一个新的版本,将需要revert的版本的内容再反向修改回去,版本会递增,不影响之前提交的内容。
查看用户名和邮箱地址:
$ git config user.name
$ git config user.email
git add -A 和 git add . 的区别:
git add -A和 git add . git add -u在功能上看似很相近,但还是存在一点差别
git add . :他会监控工作区的状态树,使用它会把工作时的所有变化提交到暂存区,包括文件内容修改(modified)以及新文件(new),但不包括被删除的文件。
git add -u :他仅监控已经被add的文件(即tracked file),他会将被修改的文件提交到暂存区。add -u 不会提交新文件(untracked file)。(git add --update的缩写)
git add -A :是上面两个功能的合集(git add --all的缩写)
git 查看单独一个文件的修改历史
1. git log filename
可以看到fileName相关的commit记录
2. git log -p filenam
可以显示该文件每次提交的diff
3. git show commitid filename
只看某次提交中的某个文件变化,可以直接加上fileName