分布式版本控制工具 git

git 是什么

  • 分布式版本控制工具
  • github 是代码托管平台。

git 有什么用

  • 保存文件的所有修改记录。
  • 使用版本号(sha1 哈希值) 进行区分。
  • 随时可浏览历史版本记录。
  • 可还原到历史指定版本。
  • 对比不同版本的文件差异。

为什么要使用 git

  • 多人协作开发一个大型项目。
  • 每个人都在代码库下载代码,然后进行修改,把大家不同版本的代码合在一起上传到平台。
  • 公司都会有自己的代码托管平台。

git 基本概念

  • 仓库:
    • 远程仓库:git init --bare 创建一个裸仓库。
    • 本地仓库:git clone ... 克隆远程仓库到本地。
  • 协议:
    • http / https
    • ssh
      • ssh 协议是一个验证授权的网络协议。
      • 使用 ssh 公钥登录 git 服务器。
        • 生成公钥和私钥ssh-keygen -t rsa
        • 安装 openssh server(可省略)。
        • 复制公钥内容到远端服务器 .ssh/authorized_keys
        • git clone ssh://root@123.249.112.139:/root/holo_render/remote_storage
  • 配置用户名和邮箱:
    • 局部配置:
      git config user.name zcoder
      git config user.email zcoder@163.com
      
    • 全局配置:
      git config --global user.name zcoder
      git config --global user.email zcoder@163.com
      
  • 版本号:40sha1 哈希值。
  • head:当前检出记录的符号引用。

请添加图片描述


git 基本操作

  • 暂存:git add
  • 提交:git commit
  • 推送:git push
  • 拉取:git fetch将远程仓库所包含分支的最新 commit-id 记录到本地文件
  • 拉取合并:git pullgit fetch + git merge
  • 查看状态:git status
  • 查看历史:git log

git 逆向操作

  • 暂存区 → 本地工作区:git restore -S
  • 本地仓库 → 暂存区:git reset --soft
  • 本地仓库 → 本地工作区:git reset --mixed
  • 本地仓库 → nullgit reset --hard

git 本地仓库整理操作

  • 整理上一次提交:git commit --amend → 相同功能多次提交复用上次提交信息。
  • 整理多次提交:git rebase -i hash1 hash2(左开右关)。
  • 只在私有仓库,也就是在 develop 分支上使用,因为提交的 commit-id 会发生变化。

git 分支操作

  • 查看分支:git branch
  • 创建分支:
    • git branch develop → 创建
    • git switch develop → 切换
    • git checkout -b develop → 创建并切换。
  • 删除分支:git branch -d develop
  • 合并分支:
    • 切换到本地 master 分支,拉取远程仓库 master 最新数据。
      git switch master
      git pull
      
    • 切换到 develop 分支,把本地 master 合并到 develop
      git switch develop
      git merge master 
      
    • 如果有冲突要解决冲突,测试代码,没问题的话就提交。
      vi api.hpp
      git add .
      git commit -m "fix:merge master"
      
    • 切换到本地 master 分支,把 develop 合并到本地 master,最后提交到远程仓库。
      git switch master
      git merge develop
      git push origin master
      

git 解决冲突

  • 冲突产生原因:不同分支修改了同一文件的同一行或者相邻行
  • 解决原则:
    • 不要影响其他人提交的功能,也不能破坏自己提交的功能。
    • 协商解决。
  • 解决方式:git merge
  • 建议:提交前先 git pull 拉取最新代码。

请添加图片描述


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值