版本控制能在软件开发中,确保由不同的人编辑同一程序文件能同步。可以帮助程序员进行代码的追踪、维护、控制等操作。
目录
6.2.3. 重命名远程仓库 - git remote rename
6.2.4. 移除远程仓库 - git remote remove
7.4.删除远程标签 - git push --delete
8.4.创建分支同时切换过去 - git checkout -b
早期的时候,Linux社区使用的是BitKeeper来进行版本控制;但是因为一些原因,BitKeeper想要收回对Linux社区的免费授权;于是Linus用了大概一周的时间,开发了Git用来取代BitKeeper;Linus完成了Git的核心设计,在之后Linus功成身退,将Git交由另外一个Git的主要贡献者Junio C Hamano来维护;
所以安全性会更高一些,公司基本上都是使用git来管理项目的,我们也会重点学习git。
要使用git,我们就需要安装git。 下载完git可以配置个人喜好或者信息。
git官网可以下载https://git-scm.com/downloads,根据对应的操作系统下载。
同时还需要查看自己的电脑是64位的还是32位的,下载对应的版本。
按照默认配置全局安装就可以了。
Git下载安装完之后,也会安装Git CMD、 Git GUI、Git Bash。点击鼠标右键就会出现Git GUI和Git Bash。
其实Git CMD就是对命令行解释程序的封装。
你可以在Git CMD运行git命令,但是后面提到的Bash更方便。
点击鼠标右键,点击Git GUI Here就可以进入。
点击鼠标右键,选择Git Bash Here就可以打开。
可以在这样的一个界面使用git命令。建议使用Git Bash。
安装Git后,要做的第一件事就是设置你的用户名和邮件地址。
需要配置用户名,也需要配置自己的邮件地址。
git config --global user.name "用户名"
git config --global user.email "电子邮箱"
使用git config --list就可以查看自己的配置信息。
在C盘也可以找到gitconfig文件,
如果用记事本方式打开可以看到里面的配置信息。
如果不想每次都输入完整的git命令,可以给每个命令设置一个别名。
git config --global alias.st status
这个命令是给status起别名st,在配置完了之后输入git st就相当于git status。
不过正常不会设置别名,完整的git命令也不长。
我们使用Git来管理代码,本地也需要有一个Git仓库。
有两种获取Git仓库的方式:
初始化仓库是用在创建一个新项目的时候。
git init
这个命令将创建一个名为.git的子目录,这个子目录有初始化Git仓库中所有的必须文件,这些文件是Git仓库的核心。
如果已经创建过Git仓库了,我们可以从服务器克隆远程仓库到本地。
git clone https://github.com/xxx/xxxxx.git
克隆开源项目的时候不需要验证,如果是闭源项目的话,就需要验证了,后面学习。
为了更好地对仓库文件进行管理,把文件划分了多个状态。一些不需要归于Git管理的文件也可以写忽略文件进行管理。
我们需要对文件进行不同状态的划分,判断是否已经归于Git仓库的管理。
未跟踪(untracked):默认情况下,Git仓库下的文件也没有添加到Git仓库管理中,我们需要通过add命令来操作;可以只添加一个文件,也可以添加所有文件。
已跟踪的文件又细分为三种状态:
有一些文件是不需要纳入Git管理的,也不希望它们出现在未跟踪文件中。
我们可以创建一个.gitignore文件,ignore是忽略的意思。编辑要忽略的文件,比如日志文件或者临时文件。
实际开发时也比较少去手动创建,Vue创建项目时也会自动创建.gitignore文件。
这是Vue创建项目时自动生成的.gitignore文件,
也可以在github上面找.gitignore文件。
里面有非常多文件的忽略文件。
一些基本的命令使用的频率是非常频繁的,比如git add和git commit -m"",以后会经常和这些命令打交道的。
想要跟踪一个新文件或者跟踪一个修改的文件就需要使用git add命令。
如果想要把所有文件都放进暂存区(Staged),就可以使用命令:
git add .
不管是修改的文件(Modified)还是未跟踪的新文件都可以使用git add . 命令一次性全部添加进暂存区(Staged)
.点代表全部。
把想要的文件git add放到暂存区里面,就可以提交了。
提交的命令git commit。加上-m后面就可以添加上提交信息了。
git commit -m "提交信息"
如果觉得先add再commit的操作比较繁琐,可以把两个操作合并成一个命令。
git commit -a -m "提交信息"
使用git status就可以检测文件的状态。查看有哪些文件处于未跟踪(Untracked)状态、修改(modified)状态、暂存(staged)状态、未修改(Unmodified)状态。
不管在什么状态,使用git status都可以检测得到。
提交的更新,克隆了某个项目之后,有时候我们想要查看一下所有的历史记录。
我们就可以使用git log命令查看提交的历史。
这个命令会列出每个提交的 SHA-1 校验和、作者的名字和电子邮件地址、提交时间以及提交说明;
如果想要简洁的提交历史,可以使用git log --pretty=oneline命令。
想要提交历史的图结构,可以使用git log --pretty=oneline --graph命令。
做切换分支合并操作的时候图结构才比较明显。
可以用git log查看自己的版本。HEAD指针指向的就是当前的版本。
常用的是回退上一个版本 git reset --hard HEAD^和回退到指定的版本git reset --hard 452ef7f
使用git reset回退到了452ef2f的版本,但是用git log查看日志,好像之前的版本不见了,而且也不知道那个版本的校验和怎么办?
可以使用git reflog查看所有的记录,包括回退的记录。
使用git reflog查看所有记录后找到想要的版本的校验和码,就可以重新回到之前的版本了。
目前我们的代码都是在本地仓库中,刚才做的那些都是在本地操作的;在开发的时候,我们大部分情况下是多人开发的,而且代码也是共享到远程仓库的。
所以我们需要一个远程仓库。
常见的远程仓库:GitHub、Gitee、Gitlab。
GitHub访问起来比较慢;Gitee开源项目需要审核比较麻烦,而且企业版是要收费的; 大部分的公司都是在自己的服务器搭建Gitlab的。
有些仓库是开源的,有些仓库的私有的,如果任何人都可以操作私有仓库的话,不利于管理私有项目,所以我们需要身份验证。
目前Git服务器验证手段有两种:
基于HTTP的凭证存储和基于SSH的密钥。
在安装git的时候默认配置有选项安装 “Git Credential Manager for Windows”的辅助工具了。也可以使用git config credential.helper的命令来验证。
这样就说明有这个辅助工具了。
克隆私有仓库的时候会做一次身份验证,后续操作都不需要重新再输入账户密码了,辅助工具已经帮你记录下来了。
如果想要删除这个凭证的话,在控制面板=>用户账户=>管理你的凭据=>Windows凭据可以管理凭证。
Secure Shell(安全外壳协议,简称SSH)是一种加密的网络传输协议,可在不安全的网络中为网络服务提供安全的传输环境。
如果我们要用SSH的方式访问仓库,就需要生产对应的公钥和私钥。
ssh-keygen -t ed25519 -C "your email"用得更多,-C后面的是注释,一般写邮箱更多一些。
1.在Git Bash输入命令,就可以生成公钥和私钥了。
2.生成的私钥和公钥会保存下来,把公钥复制下来,打开自己的远程仓库。
3.打开远程仓库服务器,配置SSH公钥,把公钥粘贴下去,并且添加一个标题。
4.密码验证,就成功添加了。
想要管理远程仓库,就需要有远程仓库,所以我们需要将远程仓库克隆下来。
git clone https://gitee.com/xxxxxxxx.git
有了远程仓库可以用一些命令管理远程仓库。
克隆下来的代码就是有自己的远程仓库的。
git remote
git remote -v
加上-v可以查看更加详细的内容。
我们可以继续添加远程仓库服务器,让本地的仓库和远程服务器仓库建立连接。
git remote add <shortname> <url>
可以给远程仓库服务器重命名,originName为原名,changedName为改后的名。
git remote rename <originName> <changedName>
可以使用命令移除远程仓库。deleteName是要删除的远程仓库名。
git remote remove <deleteName>
将当前分支(比如master)psuh本地仓库推送到远程仓库
git push
git push origin master
git fetch是从远程仓库获取最新的代码,但是没有和本地仓库合并,
需要用git merge将远程仓库的代码和本地仓库合并。
两次操作有些繁琐,我们可以通过一个命令来操作git pull。
git pull 就是 git fetch + git merge的合并。
如果多人开发,每次提交之前最好先git pull一下获取最新的代码。
Git可以给仓库历史中的某一次提交打上标签,人们会用标签来标记发布结点。
对于重大的版本我们会打上一个标签,以表现它的重要性。
Git支持两种标签:轻量标签和附注标签。
轻量标签就是只标注标签版本号,而附注标签则添加了一些额外信息。
轻量标签git tag v1.0
附注标签git tag -a v1.1 -m "添加信息"
默认情况下git push 命令是不会推送标签到远程仓库服务器上的。
所以我们需要有其他的命令来推送这个标签到共享服务器上。
推送上共享服务器之后,其他开发者从仓库拉取或者克隆的时候,就可以拿到标签了。
如果要删除本地仓库上的标签的话,可以使用命令git tag -d <tagname>,tagname就是标签的版本号。
如果想要删除远程标签,可以使用git push <remote> --delete <tagname>。
基本上所有的版本控制系统都支持分支,分支的作用是把个人的开发从开发主线上分离开来,以免影响到开发主线。
进行提交操作的时候,Git会保存一个提交对象,
Git的分支,本质上是指向提交对象的可变指针。而Git的默认分支是master,master在每次提交的时候都会自动向后移动。
Git的master分支不是一个特殊的分支,它和普通的分支没有区别,只不过git init命令会默认创建它。
创建新分支时,Git创建了一个可移动的新指针。
如果我们想要创建一个testing的分支,我们可以使用git branch testing命令。
现在有两个分支master和testing,怎么区别在哪个分支里面呢?
Git是通过一个HEAD的特殊指针进行区分的。
尽管有两个分支,但HEAD指向哪个现在就在哪个分支上。
我们可以通过git checkout <branchname>切换分支,branchname就是想要切换的分支名。
可以看到分支已经从master切换到testing了。
如果觉得先用git branch创建分支再用git checkout切换分支太麻烦的话,可以把这两个命令合并成一个git checkout -b <newbranchname>。
不仅创建了分支,还切换到了新的分支。
如果我们希望查看所有分支,可以通过以下的命令:
如果有一些分支我们不需要了,我们可以通过以下的命令删除:
有的时候需要将两个分支合并。
在Git中整合两个不同分支的修改方式有两种方法:merge和rebase。
使用merge整合不同分支的方法:
我们可以再次执行master上的合并操作:
rebase和merge是对Git历史的不同处理方法:
根据自己的特定场景选择merge或者rebase,但是永远不要在主分支上使用rebase
如果在main上面使用rebase,会造成大量的提交历史在main分支中不同; 而多人开发时,其他人依然在原来的main中,对于提交历史来说会有很大的变化;
由于Git上的分支很方便,所以在开发中产生了很多Git的工作流:在整个项目开发周期的不同阶段,可以同时拥有多个开放的分支。
比如以下的工作流:
还有比较常见的git flow
文章浏览阅读1.6k次。安装配置gi、安装数据库软件、dbca建库见下:http://blog.csdn.net/kadwf123/article/details/784299611、检查集群节点及状态:[root@rac2 ~]# olsnodes -srac1 Activerac2 Activerac3 Activerac4 Active[root@rac2 ~]_12c查看crs状态
文章浏览阅读1.3w次,点赞45次,收藏99次。我个人用的是anaconda3的一个python集成环境,自带jupyter notebook,但在我打开jupyter notebook界面后,却找不到对应的虚拟环境,原来是jupyter notebook只是通用于下载anaconda时自带的环境,其他环境要想使用必须手动下载一些库:1.首先进入到自己创建的虚拟环境(pytorch是虚拟环境的名字)activate pytorch2.在该环境下下载这个库conda install ipykernelconda install nb__jupyter没有pytorch环境
文章浏览阅读5.2k次,点赞19次,收藏28次。选择scoop纯属意外,也是无奈,因为电脑用户被锁了管理员权限,所有exe安装程序都无法安装,只可以用绿色软件,最后被我发现scoop,省去了到处下载XXX绿色版的烦恼,当然scoop里需要管理员权限的软件也跟我无缘了(譬如everything)。推荐添加dorado这个bucket镜像,里面很多中文软件,但是部分国外的软件下载地址在github,可能无法下载。以上两个是官方bucket的国内镜像,所有软件建议优先从这里下载。上面可以看到很多bucket以及软件数。如果官网登陆不了可以试一下以下方式。_scoop-cn
文章浏览阅读4.5k次,点赞2次,收藏3次。首先要有一个color-picker组件 <el-color-picker v-model="headcolor"></el-color-picker>在data里面data() { return {headcolor: ’ #278add ’ //这里可以选择一个默认的颜色} }然后在你想要改变颜色的地方用v-bind绑定就好了,例如:这里的:sty..._vue el-color-picker
文章浏览阅读640次。基于芯片日益增长的问题,所以内核开发者们引入了新的方法,就是在内核中只保留函数,而数据则不包含,由用户(应用程序员)自己把数据按照规定的格式编写,并放在约定的地方,为了不占用过多的内存,还要求数据以根精简的方式编写。boot启动时,传参给内核,告诉内核设备树文件和kernel的位置,内核启动时根据地址去找到设备树文件,再利用专用的编译器去反编译dtb文件,将dtb还原成数据结构,以供驱动的函数去调用。firmware是三星的一个固件的设备信息,因为找不到固件,所以内核启动不成功。_exynos 4412 刷机
文章浏览阅读2w次,点赞24次,收藏42次。Linux系统配置jdkLinux学习教程,Linux入门教程(超详细)_linux配置jdk
文章浏览阅读3.3k次,点赞5次,收藏19次。xlabel('\delta');ylabel('AUC');具体符号的对照表参照下图:_matlab微米怎么输入
文章浏览阅读119次。顺序读写指的是按照文件中数据的顺序进行读取或写入。对于文本文件,可以使用fgets、fputs、fscanf、fprintf等函数进行顺序读写。在C语言中,对文件的操作通常涉及文件的打开、读写以及关闭。文件的打开使用fopen函数,而关闭则使用fclose函数。在C语言中,可以使用fread和fwrite函数进行二进制读写。 Biaoge 于2024-03-09 23:51发布 阅读量:7 ️文章类型:【 C语言程序设计 】在C语言中,用于打开文件的函数是____,用于关闭文件的函数是____。
文章浏览阅读3.4k次,点赞2次,收藏13次。跟随鼠标移动的粒子以grid(SOP)为partical(SOP)的资源模板,调整后连接【Geo组合+point spirit(MAT)】,在连接【feedback组合】适当调整。影响粒子动态的节点【metaball(SOP)+force(SOP)】添加mouse in(CHOP)鼠标位置到metaball的坐标,实现鼠标影响。..._touchdesigner怎么让一个模型跟着鼠标移动
文章浏览阅读178次。项目运行环境配置:Jdk1.8 + Tomcat7.0 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。项目技术:Springboot + mybatis + Maven +mysql5.7或8.0+html+css+js等等组成,B/S模式 + Maven管理等等。环境需要1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。_基于java技术的停车场管理系统实现与设计
文章浏览阅读3.5k次。前言对于MediaPlayer播放器的源码分析内容相对来说比较多,会从Java-&amp;gt;Jni-&amp;gt;C/C++慢慢分析,后面会慢慢更新。另外,博客只作为自己学习记录的一种方式,对于其他的不过多的评论。MediaPlayerDemopublic class MainActivity extends AppCompatActivity implements SurfaceHolder.Cal..._android多媒体播放源码分析 时序图
文章浏览阅读2.4k次,点赞41次,收藏13次。java 数据结构与算法 ——快速排序法_快速排序法