掌控历史:如何通过Git版本管理工具提升你的开发效率

devtools/2024/9/22 13:31:18/

先一览全局:

在这里插入图片描述

git目录

  • 一.打开git
  • 二.git bash的基础命令
  • 三.配置git
  • 四.仓库搭建
  • 五.文件操作和状态
  • 六.忽略文件
  • 七.gitee的使用
    • 1.添加公钥
    • 2.创建仓库
  • 八.vs中使用git
  • 九.git分支常用命令
  • 十.文件差异比较
  • 十一.文件回溯和推进
  • 十二.合并冲突和消除
  • 十三.合并/压缩提交
  • 十四.远程仓库推拉
  • 十五.小乌龟图形操作git
    • 1.仓库克隆远程项目
    • 2.先创建项目,后创建远程仓库

git_6">一.打开git

在这里插入图片描述

在这里插入图片描述

git_bash_11">二.git bash的基础命令

shift+insert 是复制的快捷键
当显示不全,出现冒号的时候可以按Enter显示,最后按q退出.

cd: 移动目标
在这里插入图片描述

pwd:显示当前目录
ls/ll:显示当前目录信息
在这里插入图片描述
clear清屏
touch:创建文件
在这里插入图片描述

在这里插入图片描述
mkdir:创建目录
rm:删除文件
rm -r:删除目录
在这里插入图片描述

mv:移动文件到目录下
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
history:历史命令
在这里插入图片描述

git_43">三.配置git

查看配置
在这里插入图片描述
系统配置
在这里插入图片描述
用户配置,这里是我原来配置过,原本是没有的.

在这里插入图片描述
这里是系统配置文件
在这里插入图片描述

打开和system的配置一样.
在这里插入图片描述

用户配置信息,这个就是相当于id.
在这里插入图片描述
这里就是自己配置的信息.
在这里插入图片描述

四.仓库搭建

在这里插入图片描述
.git是隐藏的文件
在这里插入图片描述
还有远程仓库的克隆.
在这里插入图片描述
在这里插入图片描述

五.文件操作和状态

创建一个git仓库和创建一个main.cpp文件
在这里插入图片描述
查看该文件状态,未被git窗口跟踪.

在这里插入图片描述
用add,文件已经被跟踪.

在这里插入图片描述
git commit -m""文件提交到窗口,并附加备注信息.
在这里插入图片描述
进入vim可对文件内容进行修改.用cat可以查看文件内容.
在这里插入图片描述
按键盘i或者insert键可以进入到编辑模式.

在这里插入图片描述

Esc键退出编辑模式,输入:wq,这是退出并保存
在这里插入图片描述
:q! 命令是强制退出不保存.
在这里插入图片描述
修改文件后,状态改变为modified.
在这里插入图片描述
可将修改后的文件用 git add .git commit -m""添加到本地仓库.
在这里插入图片描述
也可以一步到位,添加到本地仓库.
在这里插入图片描述

六.忽略文件

.gitignore是忽略文件.
在这里插入图片描述
忽略文件的规则
在这里插入图片描述

在这里插入图片描述
.vs缓冲文件和x64编译文件已经被忽略,不能进行add.
在这里插入图片描述

gitee_118">七.gitee的使用

1.添加公钥

可以根据提示注册
在这里插入图片描述
在这里插入图片描述
设置公钥
在这里插入图片描述
在c盘用户目录下,新建一个.ssh文件夹
在这里插入图片描述
在新建的文件夹下,打开git bash.
在这里插入图片描述
就会生成这两个文件.后面有pub的是公钥.
在这里插入图片描述
我们点开,将内容复制到giteessh
在这里插入图片描述
粘贴在这里确定即可.
在这里插入图片描述

2.创建仓库

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

git_146">八.vs中使用git

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
将仓库里的HTTPS复制到上面的URL.
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
第一次的时候需要添加远程
在这里插入图片描述
还需要添加到暂存区,也可以添加到忽略文件.
第一次推送还需要验证gitee

在这里插入图片描述

在这里插入图片描述

git_165">九.git分支常用命令

先将文件添加到本地仓库
git branch 可以添加分支和查看分支
git checkout 可以切换分支

在这里插入图片描述
git checkout -b 可以同时创建和切换分支
git branch -d 可以删除分支
在这里插入图片描述
切换到另一个分支,然后进行文件修改bug,然后回到主分支,进行合并
git merge --no-ff 分支名,这是完整合并.
完整合并是会创建新的节点的,HEAD指向这个指针.
简单合并就是HEAD直接指向分支的节点.
git merge 分支名 就是快速合并.
在这里插入图片描述
git log 可以查看日志
在这里插入图片描述
git log --graph可以查看图形化日志,下面这个图形就表示先分支又合并.
在这里插入图片描述

十.文件差异比较

修改文件,用git diff 比较工作区与暂缓冲区的区别.
+号表示新增
在这里插入图片描述
将工作区修改的文件添加到暂缓区.
然后用git diff HEAD 来比较暂缓区与本地仓库的差异.
在这里插入图片描述
现在的日志就是这样了.
在这里插入图片描述

十一.文件回溯和推进

commit 后面的是哈希值,相当于这个版本的节点.可以方便回到这个版本.
在这里插入图片描述
git reset --hard 哈希值,我们这里就回溯到了最原始的版本.
这个是硬回溯直接将工作区文件也变会原来的版本.
在这里插入图片描述

十二.合并冲突和消除

编写一个有bug的文件添加到本地仓库

在这里插入图片描述
创建一个dev分支并修改文件添加到本地仓库.
然后回到主分支.

在这里插入图片描述
git merage --no-ff 完整合并.
并于git log --graph显示当前日志.
在这里插入图片描述
git reset --hard 哈希值.回到最开始的版本,创建另外一条分支,修改文件并提交至本地仓库.
在这里插入图片描述
切换到主分支,并通过git reflog 查看日志操作,推进到合并dev版本的节点.
在这里插入图片描述
此时合并另外一条分支,出现冲突,需要手动编辑文件消除冲突.
一般冲突的出现是因为合并的分支出现同一文件的部分代码不一样.
然后再将其添加到本地仓库.

git commit --amend 是修改上一条备注信息的内容.
在这里插入图片描述
最终的图形化节点结构.
在这里插入图片描述
简化图就是这样:
在这里插入图片描述

十三.合并/压缩提交

创建一个分支,编写了一个简单的bug,我们修改时不想再次提交,因为bug太简单了
在这里插入图片描述
可以用git rebase -i HEAD~2来进行合并最近两次的提交.
在这里插入图片描述
pick 修改为fixup就是要留下的提交
在这里插入图片描述

十四.远程仓库推拉

git remote add origin SSH ,来连接远程仓库,origin是备注名.
git push -u origin master.推送到远程仓库origin的master分支.
在这里插入图片描述
再推送一个分支.
在这里插入图片描述

然后另一个同事克隆仓库,选择分支进行编写,再推送到仓库.
注意分支来源.
在这里插入图片描述
在这里插入图片描述
此时再用 git pull origin fea 拉取刚刚其他人提交的.
在这里插入图片描述

git_259">十五.小乌龟图形操作git

1.仓库克隆远程项目

用小乌龟克隆远程仓库.
在这里插入图片描述

在这里插入图片描述
点击ok,克隆完成
在这里插入图片描述
可以在.git文件同目录下创建项目.

在这里插入图片描述
注意不是右击某个文件出现的,而是在空白处右击出现.
在这里插入图片描述
在这里插入图片描述
这里只是提交到了本地仓库.

在这里插入图片描述
接下来推送到远程仓库
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.先创建项目,后创建远程仓库

在这里插入图片描述
点击OK

在这里插入图片描述
提交到本地仓库.
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
提交到远程仓库.如果push操作出错一般都是因为账号有多个冲突.
在这里插入图片描述
新建一空的远程仓库,然后复制HTTPS.

在这里插入图片描述
在这里插入图片描述


http://www.ppmy.cn/devtools/115479.html

相关文章

Ubuntu NFS 搭建及配置

在 Ubuntu 上搭建和配置 NFS(Network File System)服务器,可以让其他设备通过网络访问共享的文件夹。以下是步骤指南: 1. 安装 NFS 服务器 首先,安装 NFS 服务器软件包: sudo apt update sudo apt insta…

springbootKPL比赛网上售票系统

基于springbootvue实现的KPL比赛网上售票系统 (源码L文ppt)4-068 4.2 系统结构设计 架构图是系统的体系结构,体系结构是体系结构体系的重要组成部分。KPL比赛网上售票系统的总体结构设计如图4-2所示。 图4-2 系统总体架构图 4.3数据…

链动3+1滑落模式小程序开发

链动31滑落模式是一种在电商、微商或社交电商领域常用的营销模式,通过用户推荐新用户形成团队结构,并依据团队的发展给予相应的奖励或优惠。在小程序平台上开发链动31滑落模式,需要考虑到用户体验、数据安全、奖励机制的实现等多个方面。以下…

Serverless架构

Serverless架构:漂浮在云端的轻盈与自由 类似于 Fn Project 的 Serverless 开源服务有很多,它们都旨在简化函数即服务(FaaS)的开发流程,使得开发者可以更专注于业务逻辑而不是底层基础设施。下面列举了一些知名的 Serverless 开源平台和服务…

通过springcloud gateway优雅的进行springcloud oauth2认证和权限控制

代码地址 如果对你有帮助请给个start,本项目会持续更新,目标是做一个可用的快速微服务开发平台,成为接私活,毕设的开发神器, 欢迎大神们多提意见和建议 使用的都是spring官方最新的版本,版本如下&#xff1…

Unity3D入门(二) :Unity3D实现视角的丝滑过渡切换

1. 前言 上篇文章,我们已经初步了解了Unity3D,并新建并运行起来了一个项目,使相机视角自动围绕着立方体旋转。 这篇文章,我们来讲一下Unity3D怎么过渡地切换视角。 我们继续是我上篇文章中的项目,但是需要向把Camera…

YOLOV8 OpenCV + usb 相机 实时识别

1 OpenCV 读相机 import cv2cap cv2.VideoCapture(0) while (1):# get a frameret, frame cap.read()# show a framecv2.imshow("capture", frame)if cv2.waitKey(1) & 0xFF ord(q):# cv2.imwrite("/opt/code/image/fangjian2.jpeg", frame)#passb…

24年蓝桥杯及攻防世界赛题-MISC-1

2 What-is-this AZADI TOWER 3 Avatar 题目 一个恐怖份子上传了这张照片到社交网络。里面藏了什么信息?隐藏内容即flag 解题 ┌──(holyeyes㉿kali2023)-[~/Misc/tool-misc/outguess] └─$ outguess -r 035bfaa85410429495786d8ea6ecd296.jpg flag1.txt Reading 035bf…