git笔记

本文详细介绍了Git的配置、版本库创建、文件管理、版本回退、撤销修改、远程仓库操作、分支管理和标签管理等核心功能。通过实例演示了如何进行日常的Git操作,包括提交、切换分支、合并及回退版本等,旨在帮助读者全面掌握Git的使用。

链接: git教程

一、配置git

git是分布式版本控制系统

#打开git客户端输入github用户名、邮箱地址
#用户名
git config --global user.name "Your Name"
#邮箱
git config --global user.email "email@example.com"

二、创建版本库

版本库又名仓库,英文名repository

#切换到D盘
cd /D
#创建目录
mkdir GIT
#进入新建目录(工作区)
cd GIT
#初始化
git init
#建好仓库后用ls -ah命令可以看到.git目录(默认是隐藏的)
ls -ah

三、在版本库中创建、添加、提交文本

Git添加文件需要add,commit两步。因为commit可以一次提交很多文件,所以你可以多次add不同的文件;
每次修改,如果不用git add到暂存区,那就不会加入到commit中

#创建文本
vi readme.text
#文本内容
Git is a version control system.
Git is free software.
#保存退出
:wq
#添加到仓库(放到暂存区)
git add readme.txt
#提交到仓库(把暂存区的所有内容提交到Git为我们自动创建的第一个分支master分支)
#-m后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的,这样你就能从历史记录里方便地找到改动记录
git commit -m "write a readme file"
#git commit命令执行成功后会告诉你,1 file changed:1个文件被改动(我们新添加的readme.txt文件);2 insertions:插入了两行内容(readme.txt有两行内容)。
#查看工作区的状态
git status
#查看修改内容
git diff
#显示从最近到最远的提交日志
git log
#精简日志
git log--pretty=oneline

四、版本回退

在Git中,用HEAD表示当前版本,
上一个版本就是HEAD^,
上上一个版本就是HEAD^^,
当然往上数不过来,所以写成HEAD~n

#回退到上个版本
git reset --hard head^

使用该命令后git lgo已找不到当前的版本

#用来记录你的每一次命令
git reflog
#使用commit版本号(版本号没必要写全)指定到某个版本
git reset --hard 1094a

在这里插入图片描述

五、撤销修改

场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时(没有git add),用命令git checkout – file。

git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。

#git checkout -- file可以丢弃工作区的修改
git checkout -- readme.txt

场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时(没有提交git commit),想丢弃修改,分两步,第一步用命令git reset HEAD ,就回到了场景1,第二步按场景1操作。

git reset HEAD readme.txt

场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,不过前提是没有推送到远程库。

#用来记录你的每一次命令
git reflog
#使用commit版本号(版本号没必要写全)指定到某个版本
git reset --hard 1094a

六、删除文件

#删除工作区的文件(该文件已提交到版本库)
rm readme.txt
#再恢复(从来没有被添加到版本库就被删除的文件,是无法恢复的!)
git checkout -- readme.txt
#从版本库中删除该文件
git rm readme.txt
git commit -m "remove readme.txt"

七、远程仓库

#添加远程仓库
#远程库的名字就是origin,这是Git默认的叫法,也可以改成别的
#Nantianmen-paohuituan改为自己github的用户名
#mygit改为自己gitHub的仓库
git remote add origin git@github.com:Nantianmen-paohuituan/mygit.git
#建立连接并推送内容并远程仓库
#第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送到远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
#把本地库的所有内容推送到远程库上:
git push -u origin master
#从现在起,只要本地作了提交,就可以通过命令:
git push origin master
#删除远程库
#先用git remote -v查看远程库信息:
git remote -v
#根据名字删除,比如删除origin:
git remote rm origin
#克隆远程库
git clone git@github.com:michaelliao/gitskills.git

八、分支管理

每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支。截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支。HEAD严格来说不是指向提交,而是指向master,master才是指向提交的,所以,HEAD指向的就是当前分支。在这里插入图片描述

#创建并切换到dev分支
git branch dev
git checkout dev
#上面两条可以转换为以下一条
git checkout -b dev
#列出所有分支,当前分支前面会标一个*号。
git branch
#现在,dev分支的工作完成(分支工作已完成add、commit),我们就可以切换回master分支
git checkout master
#把dev分支的工作成果合并到master分支上
git merge dev
#删除dev分支
 git branch -d dev
#强行删除没有被合并分支,使用大写的-D参数
git branch -D dev

查看分支:git branch
创建分支:git branch name
切换分支:git checkout name或者git switch name
创建+切换分支:git checkout -b name或者git switch -c name
合并某分支到当前分支:git merge name
删除分支:git branch -d name
分支合并图:git log --graph
查看远程库信息:git remote -v

实际中分支需要推送,哪些不需要呢?
master分支是主分支,因此要时刻与远程同步;
dev分支是开发分支,团队所有成员都需要在上面工作,所以也需要与远程同步;
bug分支只用于在本地修复bug,就没必要推到远程了,除非老板要看看你每周到底修复了几个bug;
feature分支是否推到远程,取决于你是否和你的小伙伴合作在上面开发。
多人协作的工作模式通常是这样:

#首先推送自己的修改:
git push origin branch-name
#推送失败,则因为远程分支比你的本地更新,需要试图合并:
git pull
#如果合并有冲突,则解决冲突,并在本地提交;
#没有冲突或者解决掉冲突后,再推送:
git push origin branch-name
#如果git pull提示no tracking information,则说明本地分支和远程分支的链接关系没有创建,用命令:
git branch --set-upstream-to branch-name>origin/branch-name

九、标签管理

Git的标签虽然是版本库的快照,但其实它就是指向某个commit的指针
创建和删除标签都是瞬间完成的

#默认标签是打在最新提交的commit上的
git tag name
#标签打在指定的commit id号上
git tag name commit_id
#还可以创建带有说明的标签,用-a指定标签名,-m指定说明文字:
git tag -a name -m "version 0.1 released" commit_id
#查看所有标签状态
git tag
#查看指定标签信息
git show name
#删除标签
git tag -d tag_name
#创建的标签都只存储在本地,不会自动推送到远程
#推送指定标签
git push origin tag_name
#推送所有标签
git push origin --tags
#删除一个远程标签(先删除本地标签)
git push origin :refs/tags/tag_name
一、基础信息 数据集名称:Bottle Fin实例分割数据集 图片数量: 训练集:4418张图片 验证集:1104张图片 总计:5522张图片 分类类别: - 类别0: 数字0 - 类别1: 数字1 - 类别2: 数字2 - 类别3: 数字3 - 类别4: 数字4 - 类别5: 数字5 - 类别6: Bottle Fin 标注格式:YOLO格式,包含多边形坐标,适用于实例分割任务。 数据格式:图片格式常见如JPEG或PNG,具体未指定。 二、适用场景 实例分割AI模型开发:数据集支持实例分割任务,帮助构建能够精确识别和分割图像中多个对象的AI模型,适用于对象检测和分割应用。 工业自动化与质量控制:可能应用于制造、物流或零售领域,用于自动化检测和分类物体,提升生产效率。 计算机视觉研究:支持实例分割算法的学术研究,促进目标检测和分割技术的创新。 教育与实践培训:可用于高校或培训机构的计算机视觉课程,作为实例分割任务的实践资源,帮助学生理解多类别分割。 三、数据集优势 多类别设计:包含7个不同类别,涵盖数字和Bottle Fin对象,增强模型对多样对象的识别和分割能力。 高质量标注:标注采用YOLO格式的多边形坐标,确保分割边界的精确性,提升模型训练效果。 数据规模适中:拥有超过5500张图片,提供充足的样本用于模型训练和验证,支持稳健的AI开发。 即插即用兼容性:标注格式直接兼容主流深度学习框架(如YOLO),便于快速集成到各种实例分割项目中。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值