Git基础

1.Git简介

1.1简述
Git(读音为/gɪt/。)是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。 [1] Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

以下摘自官网:
1.Git是一个免费的开源分布式版本控制系统,它可以快速高效地处理从小型到大型的所有项目。
2.Git易于学习,占用空间小,性能快如闪电。
它超越了像Subversion、CVS、Perforce和ClearCase这样的配置管理工具,具有像廉价的本地分支、方便的登台区域和多个工作流这样的特性。
1.2 git的优缺点
优点:1.适合分布式开发,强调个体。2.公共服务器压力和数据量都不会太大。3.速度快、灵活。4.任意两个开发者之间可以很容易的解决冲突。5.离线工作。
缺点:1.资料少(起码中文资料很少)。2.学习周期相对而言比较长。3.不符合常规思维。
4.代码保密性差,一旦开发者把整个库克隆下来就可以完全公开所有代码和版本信息。
1.3 git与svn对比
svn:SVN是集中式版本控制系统,版本库是集中放在中央服务器的
svn工作原理:在这里插入图片描述svn优缺点:
优点:集中管理方式在一定程度上看到其他开发人员在干什么,而管理员也可以很轻松掌握每个人的开发权限。
缺点:服务器单点故障 容错性差
git:Git是分布式版本控制系统,那么它就没有中央服务器的,每个人的电脑就是一个完整的版本库,这样,工作的时候就不需要联网了,因为版本都是在自己的电脑上
git工作原理:
在这里插入图片描述

2.git工作流程

如图所示:
图一图二注:

  • Working Directory(Workspace) :当前工作目录文件夹
  • Stage :暂存区
  • Repository :代码仓库(提交代码最终归宿)
    一般工作流程如下:
    1.从远程仓库中克隆 Git 资源作为本地仓库。
    2.从本地仓库中checkout代码然后进行代码修改
    3.在提交前先将代码提交到暂存区。
    4.提交修改。提交到本地仓库。本地仓库中保存修改的各个历史版本。
    5.在修改完成后,需要和团队成员共享代码时,可以将代码push到远程仓库。

3.git等其他工具安装(准备工作)

git工具下载地址:https://git-scm.com/downloads(注:根据系统和多少位就安装对应的版本)
另分享一个开放的git版本控制系统的源客户端
TortoiseGit: https://tortoisegit.org/download/
(力荐,非常好用,如果你不想要背一些繁琐的代码,这个软件提供了一套便于理解的图形化界面方便新手)
另外链接下面是相应的语言包(支持中文)
在这里插入图片描述

4.git基本命令和快速上手

  • git init 在当前文件夹创建一个git仓库,最直观的就是当前目录下多出了.git文件夹(windows下需要显示隐藏文件夹才能看到,linux下需要ls -a).
    说明:这里所有的命令在命令行中都可以 添加 –help弹出官方帮助文档 ,例如 git add --help查看git add的使用说明。
  • git add 从当前文件夹添加文件到暂存区域,以便于git追踪.
  • git commit -m “xx” 从暂存区域提交代码到代码仓库,提交说明为 “xx”
  • git diff 用来比较仓库,暂存区,工作目录的不同(用法很多)
  • git reset git reset HEAD~
    用来回退到上个提交的版本,做了两件事:1.修改了HEAD指向(仓库当前版本回退到上个),2.将仓库上个版本的文件覆盖到暂存区域,用以丢弃上次的提交,(工作目录,文件夹中的文件还没变)
  • git log 查看版本提交记录 每次commit的记录都会及说明都会在内
    还有一个显示简单摘要的办法 git log --oneline --decorate --all --graph
  • git status 查看git仓库当前状态,如有没有工作区文件未添加到暂存区(Untracked),工作区文件修改未提交到暂存区(Unstaged),暂存区的文件未提交到仓库(Changes to be committed)等等,有问题解决问题。当仓库与工作区,暂存区文件一致时,提示应该是"nothing to commit,working tree clean"
  • git checkout 同git reset一样拥有超多功能,切换分支,回复文件到工作目录,等等
  • git branch 创建分支 git branch xxx
  • git merge 合并分支
  • git clone 克隆远程仓库1.git clone git://git.kernel.org/pub/scm/git/git.git(用 git:// 协议来访问)2.git clone http://www.kernel.org/pub/scm/git/git.git(通过http 协议来访问:)3.git clone robin.hu@http://www.kernel.org/pub/scm/git/git.git(如果访问一个Git URL需要用法名和密码,可以在Git URL前加上用户名,并在它们之间加上@符合以表示分割,然后执行git clone命令,git会提示你输入密码。)4. git clone -b master2 …/server .(表示克隆名为master2的这个分支,如果省略-b 表示克隆master分支。)
    注:使用TortoiseGit截图
    在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

5远程仓库

让其他人来协作开发,此时就可以把本地仓库同步到远程仓库,同时还增加了本地仓库的一个备份。
常用的远程仓库有github:https://github.com/(最大的开源网站)码云:https://gitee.com/(GitHub中文版,对于英语不好的小伙伴力荐!能实现基本的同样功能)
5.1创建一个远程仓库
在这里插入图片描述Github支持两种同步方式“https”和“ssh”。如果使用https很简单基本不需要配置就可以使用,但是每次提交代码和下载代码时都需要输入用户名和密码。如果使用ssh方式就需要客户端先生成一个密钥对,即一个公钥一个私钥。然后还需要把公钥放到githib的服务器上。
5.2:ssh
什么是ssh? :SSH 为 Secure Shell(安全外壳协议)的缩写,由 IETF 的网络小组(Network Working Group)所制定。SSH 是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议。利用 SSH 协议可以有效防止远程管理过程中的信息泄露问题。使用ssh协议通信时,推荐使用基于密钥的验证方式。你必须为自己创建一对密匙,并把公用密匙放在需要访问的服务器上。如果你要连接到SSH服务器上,客户端软件就会向服务器发出请求,请求用你的密匙进行安全验证。

6.分支管理

在我们每次的提交,Git都把它们串成一条时间线,这条时间线就是一个分支。截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支。**HEAD指针严格来说不是指向提交,而是指向master,master才是指向提交的,所以,HEAD指向的就是当前分支。**我们可以在分支上进行创建合并删除等一系列操作
图例:在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

7.在vscode中使用git

https://blog.csdn.net/qq_40128375/article/details/84579701详细操作可见这个大佬的教程,非常详细

git config --global user.name "username" 
git config --global user.email "xxx@qq.com"

并且可以用上述方法进行git的全局配置
最后,在.git文件夹中用notpad++打开.config文件会发现多出了下面图片红框中的东西,证明推送成功。
在这里插入图片描述

8.结尾

本文章是参考几篇大佬的文章和黑马程序员所进行的总结整理,感谢几位大佬,另附博文链接和百度网盘
https://blog.csdn.net/luanxiyuan/article/details/81230149
https://blog.csdn.net/weixin_40314969/article/details/81240188
https://blog.csdn.net/qq_40128375/article/details/84579701
https://blog.csdn.net/qq_42672770/article/details/81317778
完整笔记(百度网盘地址):https://pan.baidu.com/s/1Z1evzqDp8b4OGtyET1Vw2w 提取码:rh3e

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值