Git 基本命令与操作流

news2024/9/29 17:32:39

记录 Git 中的基本命令和创建仓库、提交文件、删除文件等方面的操作


Git 基本命令

git status:查看状态

nothing to commit, working directory clean:所有已跟踪文件在上次提交后未被更改过,或者说当前目录下没有出现任何处于未跟踪状态的新文件。

Untracked files(未跟踪的文件):之前的快照(提交/ commit )中没有这些文件。

Changes not staged for commit:已跟踪文件的内容发生了变化(已修改文件),但还没有放到暂存区。要暂存这次更新,需要运行 git add 命令。

Changes to be committed :暂存区文件。创建后 git add (被追踪)还未提交的文件。

特殊的文件状态:同时属于Changes to be committedChanges not staged for commit 两种状态

$ git add README
$ vi README # 修改文件
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

    new file:   README

Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

    modified:   CONTRIBUTING.md

当将一个文件添加到暂存区(git addstage),然后修改文件内容,那么文件就会同时出现在暂存区和非暂存区。

实际上,Git 只会暂存运行了 git add 命令的文件。如果执行 commit 命令,提交的版本是运行 git add 命令时的那个版本,而不是在工作区中修改后的当前版本。

git init:初始化 repository

$ git init
Initialized empty Git repository in C:/Users/Administrator/Desktop/git_test/.git/

随即在指定目录下创建一个空的 Git repository。生成的 .git 目录是一个隐藏文件,可以直接在 资源管理器 中查看,或者在 cmd 中输入命令 dir /a 。此目录是Git来跟踪管理版本库的,不能手动修改此目录里的文件。

git init 后就运行 git add <files> 命令,开始跟踪当前目录下的文件。

git log:显示提交日志

$ git log
commit e49ffb91d8776b952000f5a15791439ea11a51fe (HEAD -> master)
Author: phil <xxxxxxxxxx@xx.com>
Date:   Tue Jan 16 19:32:31 2024 +0800
    add distributed under the GPL

commit 670e23aeddd81f8fc3151d7866ad368b959376a4
Author: phil <xxxxxxxxxx@xx.com>
Date:   Tue Jan 16 17:03:37 2024 +0800
    add distributed

commit 5f2427d23f7bc17ab29a16c37c5bb380aa033d76
Author: phil <xxxxxxxxxx@xx.com>
Date:   Tue Jan 16 16:36:16 2024 +0800
    write a readme file

显示从最近到最远的提交日志,有 commit idAuthorData 以及文件修改详细信息。和 SVN 不一样,Git 的 commit id 不是1,2,3……递增的数字,而是一个 SHA1 计算出来的十六进制数字。

commit(提交)比较多,git log 的内容在一页显示不完整,就会显示冒号 :回车键可以往下滚一行、空格键往下滚一页,以便继续查看剩余内容直至显示 (END)。英文状态下 按 q 可以退出git log 状态。

参数--prettygit log --pretty=oneline,单行显示提交日志

$ git log --pretty=oneline
e49ffb91d8776b952000f5a15791439ea11a51fe (HEAD -> master) add distributed under the GPL
670e23aeddd81f8fc3151d7866ad368b959376a4 add distributed
5f2427d23f7bc17ab29a16c37c5bb380aa033d76 write a readme file

git reset:回退版本

参数--hardgit reset --hard [HEAD~[?]]/[commit_id]/HEAD@{?}

在 Git 中,用 HEAD 表示当前版本,上一个版本就是 HEAD^,上上一个版本就是 HEAD^^,后面 HEAD~[3] 来表示(难确定目标版本与HEAD~[?]的对应关系,不建议使用);根据 git reflog 输出的 commit_id 来确定回退版本;根据 git reflog 输出的 HEAD@{?} 来回退版本。

回退版本操作也会记录在日志中,并有相应的 commit id

$ git reflog
5f2427d (HEAD -> master) HEAD@{0}: reset: moving to 5f2427d23f7bc17ab29a16c37c5bb380aa033d76
670e23a HEAD@{1}: reset: moving to HEAD^
e49ffb9 HEAD@{2}: commit: add distributed under the GPL
670e23a HEAD@{3}: commit: add distributed
5f2427d (HEAD -> master) HEAD@{4}: commit (initial): write a readme file

$ git reset --hard "e49ffb9"
HEAD is now at e49ffb9 add distributed under the GPL

git reset 除了可以回退版本,也可以把被修改的 staged 的文件回退到工作区,详见 Git 操作流撤销修改。

git reflog:显示所有操作日志

reflogReference logs(参考日志),git reflog命令可以显示所有的历史版本记录。

这不同于git log 只可以查看到 HEAD 指针及其之前的版本信息,如果版本发生过回退操作,则无法显示 HEAD 指针之后的版本情况。

在这里插入图片描述

$ git reflog
e49ffb9 (HEAD -> master) HEAD@{0}: commit: add distributed under the GPL
670e23a HEAD@{1}: commit: add distributed
5f2427d HEAD@{2}: commit (initial): write a readme file

输出结果:
commit id 的前7位:根据这7位可以将版本库恢复到对应节点状态

HEAD@{n}:表示 HEAD 指针前移两次的版本,也就是上上个版本

最后一段字符串为提交的说明信息。

git add:追踪文件

git add 命令使用文件目录的路径作为参数;如果参数是目录的路径,该命令将递归地跟踪该目录下的所有文件。这是个多功能命令:可以用它开始跟踪新文件,或者把已跟踪的文件放到暂存区,还能用于合并时把有冲突的文件标记为已解决状态等。 将这个命令理解为“精确地将内容添加到下一次提交中”而不是“将一个文件添加到项目中”要更加合适。

$ git add fileName 指定文件
# 一次 add 多个文件
$ git add file1.txt file2.txt file3.txt
# 提交被修改的和新建的文件,但不包括被删除的文件
$ git add.
# 更新所有改变的文件,即提交所有变化的文件
$ git add -u --update update tracked files
# 提交已被修改和已被删除文件,但是不包括新的文件
$ git add -A --all add changes from all tracked and untracked files 

git commit:提交

git commit -m 'commit message(提交描述) fileName'

git checkout -- file:撤销修改

# 撤销对文件的修改
$ git checkout -- file

这里有两种情况:

  1. filename 已经添加到暂存区后,又作了修改,现在撤销修改,会回到在暂存区中的状态
  2. filename 自修改后还没有被放到暂存区,现在撤销修改,会回到上次提交的状态

总之,就是让这个文件回到最近一次 git addgit commit 时的状态。

git rm file:删除文件


Git 操作流

创建 repository

  1. 创建文件夹,作为版本库/仓库/repository。在 repository 中的所有文件都可以被 Git 管理,Git 能跟踪每个文件的修改、删除,以便任何时刻都可以追踪历史,或者在将来某个时刻还原。
    Windows 中命令如下:

    md C:\Users\Administrator\Desktop\Git_test
    cd C:\Users\Administrator\Desktop\Git_test
    dir
    

    Linux 中命令如下:

    mkdir /home/git_test
    
  2. 初始化一个 Git 仓库(把上述的目录变成 Git 可以管理的仓库)

    $ git init
    Initialized empty Git repository in C:/Users/Administrator/Desktop/git_test/.git/
    

    随即在指定目录下创建一个空的 Git repository。生成的 .git 目录是一个隐藏文件,可以直接在 资源管理器 中查看,或者在 cmd 中输入命令 dir /a 。此目录是Git来跟踪管理版本库的,不能手动修改此目录里的文件。


添加文件到 repository

  1. 创建并编辑文件

    $ touch 'fileName' # 创建文件
    $ vi 'fileName' # 输入a、i、o进行插入模式
    

    按键 esc进入命令模式,输入 :wq 退出文件编辑并保存。

  2. 将文件添加到仓库

    $ git add 'fileName' # 把文件添加到仓库(可添加多个文件或多次添加)
    

    命令执行后,没有任何提示。

  3. 提交文件

    $ git commit -m 'commit message' # 把文件提交到仓库
    

    -m 后面输入的是本次提交的说明,最好输入有意义的提交/改动信息。

    git commit命令执行成功后显示:几个个文件被改动(file changed);插入了几行内容( insertions(+) )。git commit命令执行成功后会告诉你,1 file changed:1个文件被改动(我们新添加的readme.txt文件);2 insertions:插入了两行内容(readme.txt有两行内容)。

Git 添加文件到 repository 需要 addcommit 两步,以便多次 add 不同的文件,最后一次性提交。


修改 committed 的文件并再次提交

对已经提交的文件修改,并将修改后的文件再次提交。

  1. 修改文件

    # 编辑文件
    $ vi 'fileName' # 输入a、i、o进行插入模式
    

    按键 esc 进入命令模式,输入 :wq 退出文件编辑并保存。

  2. 查看当前的状态。哪个文件被修改,是否被 commit

    $ git status
    # 查看修改内容
    $ git diff readme.txt # difference(diff)
    
  3. 将修改后的文件再次提交

    $ git add readme.txt
    $ git commit -m "add distributed"
    $ git status
    $ cat 'fileName' # 将文件内容打印显示
    

删除文件

如果文件存在于版本库中(被追踪 /add),删除文件需要在工作区和版本库中都删除,仅删除工作区中的文件不会影响版本库中的文件。

$ touch file.txt
$ git add file.txt
$ git commit -m "add file.txt"

在工作区中删除文件

$ rm test.txt
$ git status
On branch master
Changes not staged for commit:
  (use "git add/rm <file>..." to update what will be committed)
  (use "git restore <file>..." to discard changes in working directory)
        deleted:    test.txt
no changes added to commit (use "git add" and/or "git commit -a")

在版本库中删除文件。

$ git rm test.txt 
$ git commit -m "remove test.txt" # 提交删除 
# output
[master b3a984f] remove test.txt
 1 file changed, 0 insertions(+), 0 deletions(-)
 delete mode 100644 test.txt

若在工作区中误删文件后,可以利用版本库中的文件还原:

$ git checkout -- test.txt

撤销修改

  1. 修改状态为 stagedcommitted 的文件,若想丢弃工作区的修改时,用命令 git checkout -- file

  2. 修改状态为 staged 的文件,并添加到了暂存区,想丢弃修改。分两步:第一步用命令 git reset HEAD <file>,然后 git checkout -- file

  3. 修改状态为 committed 的文件,并已提交但没有推送到远程库,想要撤销本次提交。用命令 git reset 回退版本。

在这里插入图片描述



参考:

Git book 2nd Edition (2014)

Git教程 - 廖雪峰的官方网站 (liaoxuefeng.com)

Git 教程 | 菜鸟教程 (runoob.com)

faster-git datawhale

【学了就忘】Git操作 — 51.git reflog命令 - 简书 (jianshu.com)

git rebase详解(图解+最简单示例,一次就懂)-CSDN博客

)

Git 教程 | 菜鸟教程 (runoob.com)

faster-git datawhale

【学了就忘】Git操作 — 51.git reflog命令 - 简书 (jianshu.com)

git rebase详解(图解+最简单示例,一次就懂)-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1396051.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一篇文章带你彻底了解flex布局

哈喽&#xff0c;大家好呀&#xff0c;我是前端理想哥&#xff0c;今天我们来聊聊 flex 布局。 好&#xff0c;主角登场。 CSS 弹性盒子模型( Flexible Box 或者 Flexbox ) 先来看看它的定义&#xff1a;弹性布局是指通过调整其内元素的宽高&#xff0c;从而在任何显示设备上…

Conmi的正确答案——eclipse C/C++显示“未解析的包含:<xxx.h>”/“Unresolved inclusion: <xxx.h>”

eclipse IDE 版本&#xff1a;2023-12 部分采自&#xff1a;解决方法&#xff1a;关于问题 “C - Unresolved inclusion: <iostream>” 解释事项&#xff1a;方法一可能版本不同&#xff0c;部分界面修改了。这里使用的是方法二的解决方法。&#xff08;或者各位大神的描…

Dubbo使用详解

简介 Dubbo是一个高性能、轻量级的开源Java RPC框架&#xff0c;由阿里巴巴公司开发并开源。它提供了三大核心能力&#xff1a;面向接口的远程方法调用&#xff0c;智能容错和负载均衡&#xff0c;以及服务自动注册和发现。Dubbo使得应用可通过高性能的 RPC 实现服务的输出和输…

ITSS内幕揭秘!不看后悔!

1️⃣ ITSS&#xff1f;那是啥玩意&#xff1f; ITSS&#xff0c;就是一套超酷的信息技术服务标准大全&#xff01;它规范了所有信息技术服务的小秘密&#xff0c;确保服务可靠又让人放心&#xff01;&#x1f4aa; 2️⃣ 哪些公司需要这个神器&#xff1f; ITSS可是个大家伙&a…

Unity 程序员UI编码规范

今天给大家分享Unity UI开发相关的一些编码和规范&#xff0c;有了这些指导规范&#xff0c;帮助你的项目获得更好的性能&#xff0c;少走弯路。Unity GUI&#xff08;也被称为UGUI&#xff09;经常是项目性能问题的来源。 考虑使用多分辨率和宽高比 大部分情况下&#xff0c…

解锁文字魔法:探索自然语言处理的秘密——从技术揭秘到应用实战!

目录 前言 关键技术——揭密自然语言处理的秘密武器&#xff01; 领域应用——自然语言处理技术在不同领域的奇妙表演&#xff01; 超越极限——自然语言处理技术面临的顽强挑战揭秘&#xff01; 科技VS伦理——自然语言处理技术的发展与伦理社会的纠结较量&#xff01; 开…

EasyX图形化学习(三)

1.帧率&#xff1a; 即每秒钟界面刷新次数&#xff0c;下面以60帧为例&#xff1a; 1.数据类型 clock_t&#xff1a; 用来保存时间的数据类型。 2.clock( ) 函数&#xff1a; 用于返回程序运行的时间,无需参数。 3.例子&#xff1a; 先定义所需帧率&#xff1a; const …

力扣 | 11. 盛最多水的容器

双指针解法–对撞指针 暴力解法public int maxArea1(int[] height) {int n height.length;int ans 0;for (int i 0; i < n; i) {for (int j i 1; j < n; j) {int area Math.min(height[i], height[j]) * (j - i);ans Math.max(ans, area);}}return ans;}双指针解法…

力扣每日一练(24-1-18)

经验一&#xff1a;不要把问题想复杂 Python&#xff1a; min_price float(inf)max_profit 0for price in prices:min_price min(min_price, price)max_profit max(max_profit, price - min_price)return max_profit C#&#xff1a; public int MaxProfit(int[] prices) {i…

MySQL(视图,存储函数,存储过程)

作业1&#xff1a; 作业实现&#xff1a; 首先创建学生表&#xff0c;课程表&#xff0c;以及学生选课表。 CREATE TABLE Student (Sno INT PRIMARY KEY,Sname VARCHAR(20) NOT NULL,Ssex CHAR(1) CHECK (Ssex IN (男, 女)),Sage INT,SDept VARCHAR(20) DEFAULT 计算机 );CRE…

AI小程序添加深度合成类目解决办法

基于文言一心和gpt等大模型做了一个ai助理小程序&#xff0c;在提交“一点AI助理”小程序时&#xff0c;审核如下&#xff1a; 失败原因1 审核失败原因 你好&#xff0c;你的小程序涉及提供提供文本深度合成技术 (如: AI问答) 等相关服务&#xff0c;请补充选择&#xff1a;深度…

骨传导蓝牙耳机怎么使用?使用骨传导耳机对人体有没有伤害?

骨传导蓝牙耳机的使用方法和传统的入耳式蓝牙耳机使用方法相差无几&#xff0c;都是通过蓝牙来进行连接使用&#xff0c;但骨传导耳机会自带内存&#xff0c;所以在此前提上可以存储音乐独立使用&#xff0c;比传统的入耳式蓝牙耳机使用更方便一些。 那么使用骨传导耳机会不会对…

【方案】世微AP51656 电流采样降压恒流驱动 60V3A LED灯 SOT89-5

1&#xff0c;方案应用&#xff1a;3A输出 LED灯BOM表 2&#xff0c;方案应用&#xff1a;3A输出 LED灯线路图 3&#xff0c;产品描述 AP51656是一款连续电感电流导通模式的降压恒流源&#xff0c;用于驱动一颗或多颗串联LED输入电压范围从 5 V 到 60V&#xff0c;输出电流 可…

17.自主练习

一、建表 1、建库、建表 # 创建数据库 create database mysql_exampleTest; use mysql_exampleTest; # 学生表 CREATE TABLE Student( s_id VARCHAR(20), s_name VARCHAR(20) NOT NULL DEFAULT , s_birth VARCHAR(20) NOT NULL DEFAULT , s_sex VARCHAR(10) NOT NULL…

油猴脚本注入js获取DY作品数据

油猴脚本的执行时机: 元素还未生成 https://bbs.tampermonkey.net.cn/thread-3843-1-1.html 而在控制台执行时, 通常元素已经生成 逻辑就是在网页每次发送请求时, 拦截它请求的响应数据作操作; 所以当用户作品很多时, 也需要一直滚动到全部作品请求加载完成, 触发下载 &#…

数据库经典面试题

习题一 1.1 创建表 ①创建Student表 mysql> create table Student ( -> Sno int primary key, -> Sname varchar(255), -> Ssex varchar(10), -> Sdept varchar(50) -> ); Query OK, 0 rows affected (0.01 sec) ②创建Course表 mysql…

树莓派4B +Ubuntu20.04+ROS1的使用(2)

首先确定一下主机与从机的ip地址&#xff08;非常重要&#xff09; 在这次实验中&#xff0c;主机是一台Ubuntu20.04.03系统的台式机&#xff0c;我们间通过这台准备来远程遥控树莓派上的ros1系统&#xff0c;它的ip地址是192.168.230.181 从机是一台搭载Ubuntu20.04桌面版ro…

项目管理十大知识领域之项目人力资源管理

一、项目人力资源管理的概述 作为项目管理的重要组成部分&#xff0c;项目人力资源管理旨在有效管理和利用项目团队的人力资源&#xff0c;以实现项目目标。它涵盖了对人员的招聘、培训、激励和绩效管理等方面&#xff0c;旨在确保项目团队的高效运转和成员的专业发展。项目人…

录课视频太大怎么办?3种方法一键瘦身~

录制视频是现代人常用的一种记录生活的方式&#xff0c;但是视频文件大小往往会很大&#xff0c;不利于存储和分享。为了解决这个问题&#xff0c;我们需要使用视频压缩软件来压缩视频文件大小&#xff0c;以便更方便地存储和分享。 方法一&#xff1a;嗨格式压缩大师 嗨格式压…

el-tree获取当前选中节点及其所有父节点的id(包含半选中父节点的id)

如下图,我们现在全勾中的有表格管理及其下的子级,而半勾中的有工作台和任务管理及其子级 现在点击保存按钮后,需要将勾中的节点id及该节点对应的父节点,祖先节点的id(包含半选中父节点的id)也都一并传给后端,那这个例子里就应该共传入9个id,我们可以直接将getCheckedK…