Android Studio的git操作

利用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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值