Git常用的命令【提交与回退】

git分布式版本控制系统 (SVN集中式版本控制系统)之间的对比

git有本地仓库和远程仓库,不同的开发人员可以分别提交自己的本地仓库并维护代码的版本控制。

然后多个人员在本地仓库协作的代码,可以提交到远程仓库中做整合。

git本地客户端安装配置

windows

远程仓库的git地址,作为我们SSH的通信

首先需要先下载git客户端,点击git bash,创建好目录

git bash和git hub 之间是通过ssh加密传输的,因此需要配置公钥,打开git bash,生成公钥私钥:ssh-keygen -t rsa -C "xxxxxxxxx@qq.com",在git hub上进行公钥配置。

git bash和github进行ssh连接,如果连接不上,可能就是不让用22端口(默认),可以使用443端口。

复制代码
$ssh -T -p 443 git@ssh.github.com #github备用的SSH地址,443端口
$nano ~/.ssh/config #编辑SSH配置文件
#配置文件中添加以下内容
Host github.com
    Hostname ssh.github.com
    Port 443
$ssh -T git@github.com #保存文件,重新尝试连接

git客户端和github连接成功示意图:

配置邮箱和用户名:以后再github提交的任何代码文件,都会附带你的邮箱和用户名信息

ubuntu

首先Linux需要安装open-SSH服务和git,生成公私钥,把公钥配置在github上(具体可以查看其他博客,这里不做讲解)

复制代码
$ sudo apt-get install open-SSH git

总结

Git常用指令

将远程仓库的代码拉取到本地

复制代码
$ git clone [github的SSH地址]

git客户端进入项目中,git log可以查看提交人和提交日期

git remote得到的是origin,是我们远程仓库的名称,可以在隐藏文件.git 的配置文件更改

复制代码
$ git remote 

可以得到代码版本的分支,也就是你工作在哪个分支上

复制代码
$ git branch -r

把工作区的代码改动,提交到暂存区。

复制代码
$ git add main.cpp #使用 git status 去查看状态

把暂存区的代码提交到本地仓库的分支上

复制代码
$ git commit -m "创建了main.cpp,书写了初始的代码"

把本地仓库的代码提交到远程仓库

复制代码
$ git push origin main # 把我本地仓库主分支的代码 提交到 远程仓库origin的主分支上

另外一个用户此时可以使用pull命令,将更新的代码版本拉到自己的本地仓库

复制代码
$ git pull

最后通过git log 可以查找到谁更新的哪块代码,有问题就找作者

此外HEAD指针指向了最新一次的代码版本。

各个阶段的回退操作

工作区-》暂存区-》本地仓库-》远程仓库

工作区的回退:

复制代码
$ git checkout -- main.cpp #在工作区修改的代码进行回退一开始的状态 或者 对应的文件回退

暂存区的回退:

复制代码
$ git reset HEAD <filename> #可以取消相应暂存区中文件的修改 或 所有

本地仓库的回退:

复制代码
$ git reset --hard <commit的id号> #commit的id号在git log下查看

远程仓库的回退:

注意:由于你本地仓库的代码有问题且提交到远程仓库了,想要回退时,别人更新过远程仓库了,可能你回退之后,把别人更新的内容也回退没了。

复制代码
$ git push -f origin main #强制用本地仓库的代码把远程仓库的代码更新
相关推荐
s_nshine5 小时前
释放C盘,迁移studio相关数据到其他盘
android·windows·android studio·内存·c盘
代码钢琴师5 小时前
从零设计一个 Java 分布式限流库:throttle4j 架构解析
github
用户065128196335 小时前
Go开发者的工具箱:gookitgoutil,900+实用函数汇集
github
DogDaoDao5 小时前
【GitHub】AutoGPT 深度技术解析:开源自主 AI Agent 平台架构全解
人工智能·程序员·开源·github·ai编程·ai agent·智能体
Python私教6 小时前
用 Claude Code 做大型重构不翻车:分批+Git 兜底+验证闭环的实战流程(2026)
git·重构·ai编程·代码重构·工程实践·claude code
SUNNY_SHUN6 小时前
把 Whisper、Moonshine、SenseVoice 统统装进手机:sherpa-onnx 离线语音部署框架,GitHub 10.9K Star
人工智能·智能手机·whisper·github
DogDaoDao6 小时前
【GitHub】Hermes Agent 深度技术分析
程序员·大模型·github·ai编程·ai agent·智能体·hermers agent
衫水6 小时前
Windows Server Nginx 代理企业内网 API 偶发超时处理与保活 SOP(20260608))
运维·windows·nginx
Shawn Dev7 小时前
团队协作中的 Git Tag 最佳实践:从入门到精通
大数据·git·elasticsearch
沉默王二7 小时前
阿里云 OCR+LiteParse,让扫描件 PDF 也能被 RAG 检索到!
github·agent·ai编程