GIT工具学习【1】:基本操作

server/2025/3/6 23:23:44/

目录

  • 0.本地代码分区
  • 1.配置自己的个人信息(设置一次即可)
  • 2.新建仓库
  • 3.提交代码到暂存区(加入购物车)
  • 4.从暂存区撤回(不会改变工作区文件)
  • 5.恢复指定版本(会改变工作区文件)
    • 5.1:第一种情况
    • 5.2:第二种情况
    • 5.3:第三种情况
  • 7.忽略文件
  • 8.查看信息
    • git status (暂存区和工作区的区别)
    • git log(查看历史提交记录)
  • 9.乱码问题解决
  • 10.使用别名

这两张图大概看看就可以,有个概念即可
在这里插入图片描述
在这里插入图片描述
链接: git官网
写在前面
我坚持认为,用得上的知识才是有用的,所以学习技能要以实际需求为导向,比如git工具可以管理linux这种庞大的项目,但是问题是,你需要嘛?
我们可以先找把自己的项目实现版本管理,git工具已经有极大的帮助了。

0.本地代码分区

git一共有三个区
工作区:就是我们编辑的那些文件夹,写的那些代码
暂存区:运行add命令就是把文件放到这个区里面
分支区:运行commit命令把暂存区提交到分支区,也就是真正到了git里面。

问题:why not submit directly to the branch area?
为什么要有暂存区,直接提交到分支区不好吗?
答案是:
当项目足够大的时候,这边改一点,那边改一点,暂时一点点的add暂存区,然后一次性的commit,
比如超市购物的时候,不能买一个饼干付一次款,买个饮料付一次款,最好是先放在购物车里面,最后一次性的结算。
很明显,购物车和这个缓存区的发明逻辑很像。
当然还有其他的好处,慢慢就体会到了。

1.配置自己的个人信息(设置一次即可)

这里相当与设置你的身份证,每一次提交都有信息留下,
注意:如果用户名和邮箱设置错了,重新设置一个正确的即可,会覆盖掉的。

$ git config--global user.name "dleid" #你的用户名
$ git config --global user.email"dleid@qq.com" # 配置你的邮箱
$ git config --global init.defaultBranch master # 配置主分支#查看设置的用户名
$ git config --global user.name  
# 查看设置的邮箱
$ git config --global user.email

2.新建仓库

进入到项目文件夹下,运行下面的命令。

$ git init

init之后会在当前路径下新建.git隐藏文件夹,这个文件夹就是版本区,如果想删除库,可以用rm -rf .git(要谨慎删除)(linux命令),window系统设置显示隐藏文件,直接删除即可。

3.提交代码到暂存区(加入购物车)

add可以每次添加一个文件,文件夹,整个文件夹
根据需求抄一下就可以了。

提交单个文件
$ git add src/status_interfaces/package.xml
提交单个文件夹
$ git add src
提交所有
$ git add.

4.从暂存区撤回(不会改变工作区文件)

能加进去,也能撤回去,开车时候,学会刹车一定比加油门更重要。

#清空暂存区
$ git reset
#从暂存区撤回指定文件
git reset <filename>

5.恢复指定版本(会改变工作区文件)

如果我们的代码改出了各种各样的问题,我们要恢复上一个版本。

5.1:第一种情况

仅仅在工作区更改,希望恢复到上一次提交状态:git checkout 恢复到最近一次提交的状态

5.2:第二种情况

已经add到暂存区:
git reset 把文件从暂存区撤销掉
再次运行git checkout 覆盖掉工作区版本

5.3:第三种情况

已经commit提交了:
git reset --hard<commit的hash码>,这个时候工作区恢复为上一个版本,暂存区不变
注意如果已经远程到了服务器,这个命令要小心。

大家注意一个点:只要提交的版本,不管是不是覆盖之类,都是丢失不了的,可以用git reflog查看所有提交过的版本

7.忽略文件

很多的临时文件,我们是不需要管理的,比如备份文件等等是不需要关心的。

$ git add .gitignore
$ git commit -m "添加Git忽略文件"
$ git add.
$ git commit -m "测试提交临时目录"

##. 示例
以下是一个常见的 .gitignore 文件示例:

# 忽略日志文件
*.log# 忽略临时文件
*.tmp# 忽略编译生成的文件
*.pyc
*.class# 忽略 IDE 配置文件
.vscode/
.idea/# 忽略依赖文件夹
node_modules/# 忽略特定文件夹中的所有文件
build/
dist/# 忽略特定文件,但排除特定文件
*.txt
!README.txt

.gitignore 是一个非常实用的工具,可以帮助你保持仓库的整洁,避免不必要的文件被提交到版本控制中。

8.查看信息

git_status__117">git status (暂存区和工作区的区别)

运行这个命令之后
1.对列出版本库和暂存区的差异:显示如果暂存区版本比较新,就显示需要提交到版本库
在这里插入图片描述
2.对比暂存区和工作区文件的区别:如果工作区有更新,就显示文件有更改
在这里插入图片描述

如果想看详细的更改内容,可以用git diff,也可以git diff ,只显示指定的文件变更

git_log_128">git log(查看历史提交记录)

用下面的命令行查看log信息是比较直观的,但是命令行会比较长,可以使用别名的方式简化

查看历史提交记录
git log --all --pretty=oneline --abbrev-commit --graph

在这里插入图片描述
别名的使用方法:
在这里插入图片描述

9.乱码问题解决

第一步:看看是不是管用,不管用就进行第二步操作

git config --global core.quotepath false

第二步:git bash空白处右击选择options
在这里插入图片描述

10.使用别名

可以使用下面的命令,实现输入git lg 达到自定义输出提交记录的目的。

git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"

http://www.ppmy.cn/server/172996.html

相关文章

Redis设计与实现-数据结构

Redis数据结构 1、RedisObject对象2、简单动态字符串2.1 SDS定义2.2 SDS与C语言的区别2.3 SDS的空间分配策略2.3.1 空间预分配2.3.2 惰性空间释放 2.4 SDS的API 3、链表3.1 链表的定义3.2 链表的API 4、字典4.1 字典的定义4.2 哈希算法4.3 哈希表的扩缩4.3.1 哈希表扩缩的判断依…

神旗视讯Linux client 3.4版本发布和开源

在国产化替代的大潮中&#xff0c;神旗视讯推出专为统信 Linux、麒麟 Linux OS 打造打造的开源视频会议客户端&#xff0c;全面适配国产 x86 及 arm64 架构 CPU&#xff0c;以稳定、安全、灵活的特性&#xff0c;为国产操作系统用户带来前所未有的高效沟通体验&#xff0c;同时…

【Elasticsearch】Index Lifecycle Management

Elasticsearch 的索引生命周期管理&#xff08;Index Lifecycle Management&#xff0c;简称 ILM&#xff09;是一种自动化管理索引生命周期的功能&#xff0c;旨在帮助用户根据索引的使用模式和数据价值&#xff0c;高效地管理和优化索引的存储、性能和成本。以下是关于 Elast…

软件工程---净室软件工程

净室软件工程是一种软件开发方法&#xff0c;旨在通过形式化的数据和严格的测试来提高软件的可靠性和减少缺陷的数量。它的核心思想是在软件开发过程中最小化或消除软件缺陷&#xff0c;从而提高软件的质量和可靠性。这种方法强调在软件生命周期的早期阶段使用形式化方法进行规…

CMake学习笔记(一):工程的新建和如何将源文件生成二进制文件

cmake是我们在工作过程中比较常见的一个工具&#xff0c;该系列文章是自己用来学习的笔记。目前只是记录下自己学习cmake的过程中的一些重要的知识点&#xff0c;其是以项目需求为导向并非完整的cmake的学习路线和系统&#xff0c;同样也并非适合所有的人。 1.生成一个可执行文…

国产化替换案例:CACTER邮件网关为Groupwise系统加固邮件安全防线

电子邮件作为企业信息流转的命脉&#xff0c;承载着商业机密与客户数据。然而&#xff0c;网络攻击手段日益复杂&#xff0c;钓鱼邮件等威胁正快速侵蚀企业安全防线。据《2024年第四季度企业邮箱安全性研究报告》显示&#xff0c;2024年Q4企业邮箱用户遭遇的钓鱼邮件数量激增至…

Qt:文件

目录 前言 QFile的使用 QFileInfo的使用 前言 关于文件相关操作&#xff0c;之前也学习过很多&#xff1a; C语言中 fopen 打开文件 fread fwrite 读写文件 fclose 关闭文件C中 fstream 打开文件 << >> 读写文件 close 关闭文件Linux中 open 打开文件 read wr…

如何配置虚拟机连接finalshell并克隆

在VMware中我们在后期的学习中是必须要用到fianlshell这个工具&#xff0c;首先在我们在VMware中将虚拟机的IP全部完成后&#xff0c;可以开始克隆 了。 找到自己的虚拟机&#xff0c;先关闭虚拟机&#xff0c;然后右键管理&#xff0c;找到克隆&#xff0c;在一步步的下一步后…