码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Git常用操作


    目录

    如何配置ssh key

    如何clone整个仓库到本地

    如何clone 其中一个分支到本地

    fork和clone的区别

    如何新建并切换分支

    如何保存本地的代码并且提交commit到自己的分支

    如何push commit到远程仓库

    如何向主分支提交pr

    如何merge代码,注意这里你需要了解一下merge和rebase的区别

    git stash 保存当前的工作进度

    main分支更新了新文件,test2分支少了main分支的新文件怎么办?

    想更新最新的主分支,然后再拉出一条新的分支


    如何配置ssh key

    为了不用多次验证

    生成新的 SSH 密钥并将其添加到 ssh-agent - GitHub 文档

    新增 SSH 密钥到 GitHub 帐户 - GitHub 文档

    测试 SSH 连接 - GitHub 文档

    Github配置ssh key的步骤(大白话+包含原理解释)_github ssh key_风中一匹狼v的博客-CSDN博客


    如何clone整个仓库到本地

    创建一个新的文件夹  

    命令:mkdir

    输入git init 本地仓库初始化

    克隆仓库 - GitHub 文档

    如何clone 其中一个分支到本地

    git clone -b next “git地址”

    命令:-b 分支名

    fork和clone的区别

    Clone(克隆):

    • git clone是用于复制一个现有的Git仓库到本地计算机的命令。它用于获取一个完整的代码仓库,包括所有的分支、提交历史和文件。
    • 当你使用git clone时,你会创建一个与原始仓库完全一样的副本,可以在本地进行修改、提交和操作。
    • 克隆通常用于从远程仓库获取一个本地副本,以便进行开发、测试和协作。
    1. Fork(分叉):

      • fork是一种GitHub等Git托管服务特有的概念。它是在托管服务上复制(分叉)一个公共代码仓库的操作,以创建一个独立的、与原始仓库相关联的副本。
      • 当你对一个项目进行分叉时,你会在你的GitHub账号下创建一个新的仓库,该仓库包含了原始仓库的所有内容,但你可以自由地在自己的分叉中进行修改和提交。
      • 分叉通常用于贡献开源项目,你可以在自己的分叉中进行修改,然后向原始项目发起拉取请求(Pull Request),以便原始项目的维护者考虑合并你的更改。

    如何新建并切换分支

    查看所有分支

    git branch

    创建

    git branch (branchname)

    切换

    git checkout (branchname)

      git checkout -b (branchname) 命令来创建新分支并立即切换到该分支下

    删除

    git branch -d (branchname)

    合并

    git merge change_site

    如何保存本地的代码并且提交commit到自己的分支

    git add .

    git commit -m "提交的信息"

    git push origin develop(远程分支名称/和本地分支名称一样)

    使用Git 将本地代码提交到远程分支_我是一只探索的程序猿的博客-CSDN博客


    如何push commit到远程仓库

    git add .

    git commit -m "提交的信息"

    git push origin master


    如何向主分支提交pr

    如何在github上提交PR(Pull Request)-腾讯云开发者社区-腾讯云

    如何提交一个优秀的pr | ChunJun 纯钧


    如何merge代码,注意这里你需要了解一下merge和rebase的区别

    git merge 会在 feature 分支中新增一个新的 merge commit,然后将两个分支的历史联系在一起

    rebase 会将整个 feature 分支移动到 master 分支的顶端,从而有效地整合了所有 master 分支上的提交。

    如果你使用git merge,将feature分支合并到master分支,会创建一个新的合并提交,保留两个分支的提交历史,可以清晰地看到合并的地方和不同的地方。

    如果你使用git rebase,将feature分支通过rebase添加到master分支的顶端,会产生一个线性的提交历史,看起来就像是feature分支的更改是在master分支上按顺序添加的,不会保留原始的分支历史。这可以使提交历史更加整洁,但也可能导致冲突和提交历史的混淆,特别是在多人协作的情况下。

    【Git】:git rebase和git merge有什么区别? | JoyoHub


    git stash 保存当前的工作进度

    main分支更新了新文件,test2分支少了main分支的新文件怎么办?

    1. 将 test2 分支切换到当前分支。
      git checkout test2
    2. 从远程服务器获取最新更改,即从main 分支中获取最新代码;这将更新本地 main 分支的代码到最新的版本,并将所有最新提交从远程获取到您的本地仓库。
      git pull origin main 
    3. 将 main 分支的代码合并到您的 test2 分支。
      git merge main
    4. 这将应用您在 main 分支上所做的更改到 test2 分支。
    5. 处理可能会出现的合并冲突,合并冲突可以多种方法处理。如果代码之间没有冲突,在此完成后,新的代码应该可以在 test2 分支上同步。

    想更新最新的主分支,然后再拉出一条新的分支

    1. 确认当前所在分支
      在命令行中使用以下命令确认当前所在的分支:
      git branch
    2. 获取最新的主分支代码
      在命令行中使用以下命令从远程仓库获取最新的主分支代码:这将从 origin 远程仓库的主分支中获取最新的代码,并将其更新到您的本地主分支中
      git pull origin main
    3. 创建新的分支
      在命令行中使用以下命令创建一个新的分支(例如,名为 my-new-feature):该命令将创建一个新分支 my-new-feature 并切换到该分支。
      git checkout -b my-new-feature
    4. (可选)添加更新后的代码
      如果您想在新的分支中添加最新的代码,您可以对其进行相应修改和提交。
      git add .     git commit -m "Update with latest code from main"
    5. 推送新分支
      最后,使用以下命令将新分支推送到远程仓库。
      git push -u origin my-new-feature
    6. 第一次使用该命令时,需要添加 -u 或 --set-upstream 选项来将新分支链接到远程仓库。以后就可以使用 git push 命令来将代码推送到远程仓库。

    以上步骤完成后,您的本地仓库就更新了最新的主分支,并创建了一个新分支。您可以在该新分支上添加自己的代码,同时保持主分支不受影响。

    参考:

    作者:耳东
    链接:https://leetcode.cn/circle/discuss/KjCjkH/
    来源:力扣(LeetCode)
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

    Chatgpt

  • 相关阅读:
    MongoDB-介绍与安装部署
    Speedoffice(word)如何添加小方框和勾
    Ubuntu 22.04 x86_64 源码编译 pytorch-v2.0.1 笔记【2】编译成功
    SQL——左连接(Left join)、右连接(Right join)、内连接(Inner join)
    JS事件循环
    scikit-learn机器学习算法封装
    代码随想录训练营day48, 打家劫舍系列问题
    物联网(IoT)的北向和南向
    操作系统——进程间通信——共享内存、消息队列、信号量
    REST API设计原则:构建可扩展、易维护的 API
  • 原文地址:https://blog.csdn.net/weixin_42173016/article/details/133710650
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号