首页 技术 正文
技术 2022年11月6日
0 收藏 663 点赞 1,014 浏览 2385 个字

本文主要记录了git中,错误的撤销和文件的删除。


撤销修改

    这里有3中情况

  1. 改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout — file。
  2. 不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了1,第二步,按照1操作。
  3. 已经提交了不合适的修改到版本库时,想要撤销本次提交,可以版本回退,不过前提是没有推送到远程库。
//第一种撤销:工作区撤销
ubuntu@myubuntu:~/joe/learngit$ vi readme.txt //工作区的错误还没有add到暂存区
ubuntu@myubuntu:~/joe/learngit$ git status
位于分支 master
尚未暂存以备提交的变更:
(使用 "git add <file>..." 更新要提交的内容)
(使用 "

git checkout — <file>…”

 丢弃工作区的改动)    修改:     readme.txt修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
ubuntu@myubuntu:~/joe/learngit$

git checkout —

 readme.txt
ubuntu@myubuntu:~/joe/learngit$ vi readme.txt
//第二种撤销:暂存区撤销
ubuntu@myubuntu:~/joe/learngit$ vi readme.txt
ubuntu@myubuntu:~/joe/learngit$ git add readme.txt //错误的文件已经提交到暂存区了
ubuntu@myubuntu:~/joe/learngit$ git status
位于分支 master
要提交的变更:
(使用 "

git reset HEAD <file>…”

 撤出暂存区)    修改:     readme.txtubuntu@myubuntu:~/joe/learngit$ git reset HEAD readme.txt
重置后撤出暂存区的变更:
M readme.txt
ubuntu@myubuntu:~/joe/learngit$ vi readme.txt
ubuntu@myubuntu:~/joe/learngit$ git status //撤出暂存区后,还需使用checkout丢弃工作区的改动
位于分支 master
尚未暂存以备提交的变更:
(使用 "git add <file>..." 更新要提交的内容)
(使用 "git checkout -- <file>..." 丢弃工作区的改动) 修改: readme.txt修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
ubuntu@myubuntu:~/joe/learngit$

git checkout —

 readme.txt
ubuntu@myubuntu:~/joe/learngit$ vi readme.txt
//第三种已经提交,使用版本回退(学习笔记2)

文件的删除

  1. 使用rm删除文件,然后git add filename添加到暂存区,git commit 提交。
  2. 直接使用git rm filename ,不用git add直接git commit即可。
//第一种方法git rm file
ubuntu@myubuntu:~/joe/learngit$ ls
abc.c readme.txt
ubuntu@myubuntu:~/joe/learngit$

git rm

 abc.c
rm 'abc.c'
ubuntu@myubuntu:~/joe/learngit$ git status
位于分支 master
要提交的变更:
(使用 "git reset HEAD <file>..." 撤出暂存区) 删除: abc.cubuntu@myubuntu:~/joe/learngit$

git commit -m “del abc”

[master 020f927] del abc
file changed, insertions(+), deletions(-)
delete mode abc.c
ubuntu@myubuntu:~/joe/learngit$ git status
位于分支 master
无文件要提交,干净的工作区
ubuntu@myubuntu:~/joe/learngit$ ls
readme.txt
//第二种方法rm file
ubuntu@myubuntu:~/joe/learngit$ ls
ab.c readme.txt
ubuntu@myubuntu:~/joe/learngit$ rm ab.c
ubuntu@myubuntu:~/joe/learngit$ ls
readme.txt
ubuntu@myubuntu:~/joe/learngit$ git status
位于分支 master
尚未暂存以备提交的变更:
(使用 "git add/rm <file>..." 更新要提交的内容)
(使用 "git checkout -- <file>..." 丢弃工作区的改动) 删除: ab.c修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
ubuntu@myubuntu:~/joe/learngit$ git add ab.c
ubuntu@myubuntu:~/joe/learngit$ git status
位于分支 master
要提交的变更:
(使用 "git reset HEAD <file>..." 撤出暂存区) 删除: ab.cubuntu@myubuntu:~/joe/learngit$

git commit -m “del ab.c”

[master 0ad1dfe] del ab.c
file changed, insertions(+), deletions(-)
delete mode ab.c
ubuntu@myubuntu:~/joe/learngit$ git status
位于分支 master
无文件要提交,干净的工作区
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,090
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,567
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,415
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,187
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,823
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,906