Git基本原理介绍及常用指令

文章目录


前言

如果你用Microsoft Word写过论文,那你一定有这样的经历:想删除一个段落,又怕将来想恢复找不回来,怎么办?有办法,先把当前文件"另存为......"一个新 的Word文件,再接着改,改到一定程度,再"另存为......"一个新文件,这样一直改下去,最后你的Word文档变成了这样:

过了一周,你想找回被删除的文字,想保留最新的一个,然后把其他的删掉,又怕哪天会用上,还不敢删。如果有一个软件,不但能自动帮我记录每次文件的改动,还可以让同事协作编辑,这样就不用自己管理一堆类似的文件了,也不需要把文件传来传去。如果想查看某次改动,只需要在软件里瞄一眼就可以,岂不是很方便?

版本管理软件可以帮我们完成文件管理。


一、Git是什么?

Git究竟是怎样的一个系统?官方解释为一个开源的分布式版本管理工具。

简单理解:Git是管理我们文件的工具,记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统。

集中化的版本控制系统

比如 CVS,Subversion 等,都有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连到这台服务器,取出最新的文件或者提交更新。

分布式版本控制系统

客户端并不只提取最新版本的文件快照,而是把代码仓库完整地镜像下来。这么一来,任何一处协同工作用的服务器发生故障,事后都可以用任何一个镜像出来的本地仓库恢复。因为每一次的提取操作,实际上都是一次对代码仓库的完整备份。

工作时不需要联网

更加安全

二、Git基本概念

在Git中文件 有三种状态,文件可能处于其中之一:

  • 已修改(modified) - 已修改表示修改了文件,但还没保存到数据库中。
  • 已暂存(staged) - 已暂存表示对一个已修改文件的当前版本做了标记,使之包含在下次提交的快照中。
  • 已提交(committed) - 已提交表示数据已经安全的保存在本地数据库中。

与文件状态对应的,不同状态的文件在 Git 中处于不同的工作区域:

  • 工作区(Working Directory):你的项目目录(电脑里能看到的目录)。当你 git clone 一个项目到本地,相当于在本地克隆了项目的一个副本。工作区是对项目的某个版本独立提取出来的内容。这些从 Git 仓库的压缩数据库中提取出来的文件,放在磁盘上供你使用或修改。
  • 暂存区(Staging Area/Index):暂存区是一个文件,保存了下次将提交的文件列表信息,一般在 Git 仓库目录中。有时候也被称作 `'索引'',不过一般说法还是叫暂存区。
  • 版本库(Repository):存储项目历史记录的地方,存储项目历史记录的地方,可以是本地的,也可以是远程服务器上的。
  • 本地仓库(Remote):本地电脑存储历史记录区域。
  • 远程仓库(Remote):托管在服务器上的代码副本,通常用于团队协作。

三、git命令操作

git软件安装后在桌面不会有快捷图标,我们需要点击右键,从弹出框中选择Git Bash Here命令。

在弹出的命令窗口使用git命令进行操作。

配置用户信息

c 复制代码
$ git config --global user.name "John Doe"
$ git config --global user.email johndoe@example.com

常用指令

①git clone :克隆一个已创建的仓库

c 复制代码
# 通过 SSH
$ git clone ssh://user@domain.com/repo.git

#通过 HTTP
$ git clone http://domain.com/user/repo.git

②git pull <远程主机名> <远程分支名>:<本地分支名>

c 复制代码
# 取回origin主机的next分支,与本地的master分支合并
git pull origin next:master

# 如果远程分支是与当前分支合并,则冒号后面的部分可以省略。
git pull origin next

# 上面的命令实质上等同于先做git fetch,再做git merge。
git fetch origin
git merge origin/next

# 合并需要采用rebase模式
git pull --rebase <远程主机名> <远程分支名>:<本地分支名>

③分支的使用:

c 复制代码
# 查看本地分支
git branch

# 查看远程分支
git branch -r

# 创建本地分支(注意新分支创建后不会自动切换为当前分支)
git branch [name]

# 切换分支
git checkout [name]

# 创建新分支并立即切换到新分支
git checkout -b [name]

# 强制删除一个分支
git branch -D [name]

# 合并分支(将名称为[name]的分支与当前分支合并)
git merge [name]

# 查看各个分支最后提交信息
git br -v

# 查看已经被合并到当前分支的分支
git br --merged

# 查看尚未被合并到当前分支的分支
git br --no-merged

④git status:显示工作路径下已修改的文件:

⑤git add命令将当前工作区内容存入版本库暂存区

c 复制代码
 单独存一个文件        git add index.txt  
 单独存一个文件夹      git add director/
 把所有文件存入暂存区   git add .

⑥git commit:暂存区的目录树会写到版本库(对象库)中,master分支会做相应的更新,即master最新指向的目录树就是提交时原暂存区的目录树。

⑦git log:从最新提交开始,显示所有的提交记录(显示hash, 作者信息,提交的标题和时间)

c 复制代码
# 显示某个用户的所有提交
$ git log --author="username"

⑧通过git push命令将本地库内容推送到远程库,git pull 命令拉取远程库内容到本地工作区。

⑨git fetch:相当于是从远程获取最新版本到本地,不会自动merge.

git pull:相当于是从远程获取最新版本并merge到本地.

某种意义上git fetch会更安全。

⑩如果你的提交信息 (commit message) 写错了且这次提交 (commit) 还没有推(push), 你可以通过下面的方法来修改提交信息(commit message):

c 复制代码
git commit --amend

总结

Git不仅是一个工具,更是一种帮助团队高效协作的方式。掌握Git,可以帮助你更好地管理代码,提高开发效率。

相关推荐
联蔚盘云6 小时前
2024.1.22 安全周报
经验分享
@PHARAOH9 小时前
HOW - 基于master的a分支和基于a的b分支合流问题
前端·git·github·分支管理
汇能感知9 小时前
光谱相机在智能冰箱的应用原理与优势
经验分享·笔记·科技
Tech智汇站10 小时前
Quick Startup,快捷处理自启程序的工具,加快电脑开机速度!
经验分享·科技·学习·学习方法·改行学it
Pandaconda11 小时前
【Golang 面试题】每日 3 题(四十一)
开发语言·经验分享·笔记·后端·面试·golang·go
Lucky GGBond11 小时前
git远程仓库如何修改
java·git
汇能感知12 小时前
摄像头模块如何应用在宠物产品领域
经验分享·笔记·科技·宠物
扎克begod13 小时前
Git进阶笔记系列(01)Git核心架构原理 | 常用命令实战集合
java·git·架构·github·springboot
Rinai_R13 小时前
【Golang/gRPC/Nacos】在golang中将gRPC和Nacos结合使用
经验分享·笔记·学习·微服务·nacos·golang·服务发现
樊南16 小时前
【esp32-uniapp小程序】uniapp小程序篇02——Hbuilder利用git连接远程仓库
git·小程序·gitee·uni-app·hbuilder·torisegit