码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • git 使用


    参考
    https://git-scm.com/book/zh/v2/Git-%E5%9F%BA%E7%A1%80-%E8%8E%B7%E5%8F%96-Git-%E4%BB%93%E5%BA%93
    在这里插入图片描述
    文件的状态变化周期

    文章目录

      • git 基础
        • 检查当前文件状态、查看已暂存和未暂存的修改
        • 暂存前后的变化
        • 跟踪新文件
        • 提交更新
        • 移除文件
        • 移动文件、重命名操作
        • 查看提交历史
        • 撤消对文件的修改
        • 查看远程仓库
        • 推送到远程仓库
        • 查看某个远程仓库
        • 远程仓库的重命名与移除
      • git 分支
        • 分支切换
        • 分支的合并
        • 删除分支
        • 删除远程分支
        • 拉取
        • Git 分支 - 远程分支
        • Git 分支 - 变基
        • git 补丁
        • git设置默认vim

    git 基础

    忽略文件

    .gitignore # https://github.com/github/gitignore
    
    • 1

    检查当前文件状态、查看已暂存和未暂存的修改

    git status
    git status -s       #状态简览
    git status --short
    
    • 1
    • 2
    • 3

    暂存前后的变化

    git diff
    git diff --staged     #比对已暂存文件与最后一次提交的文件差异 
    git diff --cached     #查看已经暂存起来的变化
    
    • 1
    • 2
    • 3

    跟踪新文件

    git add xxx
    
    • 1

    提交更新

    git commit xxx
    git commit -m  "xxx"
    
    • 1
    • 2

    移除文件

    git rm xxx
    
    • 1

    移动文件、重命名操作

    git mv xxx xxxc
    
    • 1

    查看提交历史

    git log
    git log -p -2     #显示每次提交所引入的差异(按 补丁 的格式输出),使用 -2 选项来只显示最近的两次提交
    
    git log --stat    #除了显示基本信息之外,还附带了每次提交的变化
    git log --pretty=oneline         #oneline 会将每个提交放在一行显示,--pretty 使用不同于默认格式的方式展示提交历史
    git log --pretty=format:"%h - %an, %ar : %s"        #输出对后期提取分析格外有用
    git log --since=2.weeks          # 限制输出长度 --since 和 --until 这种按照时间作限制的选项很有用
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    撤消对文件的修改

    git checkout -- xxx
    git reset HEAD  #撤消之前所做的修改
    
    • 1
    • 2

    查看远程仓库

    git remote
    git remote -v        #显示需要读写远程仓库使用的 Git 保存的简写与其对应的 URL
    git remote add   #添加一个新的远程 Git 仓库
    
    • 1
    • 2
    • 3

    推送到远程仓库

     git push origin master
    
    • 1

    查看某个远程仓库

    git remote show origin
    
    • 1

    远程仓库的重命名与移除

    git remote rename xxx xxxc
    git remote remove xxx
    git remote rm     xxx
    
    • 1
    • 2
    • 3

    git 分支

    分支切换

    git checkout testing
    git log --oneline --decorate --graph --all     #输出提交历史、各个分支的指向以及项目的分支分叉情况
    git checkout -b                 #创建新分支的同时切换过去
    
    • 1
    • 2
    • 3

    分支的合并

    git merge xxx
    
    • 1

    删除分支

    git branch -d xxx
    git branch -D xxx            #强制删除
    
    • 1
    • 2

    删除远程分支

    git push origin --delete xxx
    
    • 1

    分支管理

    git branch
    git branch -v                    #查看每一个分支的最后一次提交
    git branch --merged              #查看哪些分支已经合并到当前分支
    git branch --no-merged           #查看所有包含未合并工作的分支
    
    • 1
    • 2
    • 3
    • 4

    拉取

    git pull      #会查找当前分支所跟踪的服务器与分支, 从服务器上抓取数据然后尝试合并入那个远程分支。
    #git pull 相当于是一个 git fetch 紧接着一个 git merge 命令
    git fetch     #服务器上抓取本地没有的数据时,它并不会修改工作目录中的内容
    
    • 1
    • 2
    • 3

    Git 分支 - 远程分支

    git remote show 
    
    • 1

    Git 分支 - 变基

    https://git-scm.com/book/zh/v2/Git-%E5%88%86%E6%94%AF-%E5%8F%98%E5%9F%BA

    git 补丁

    git format-patch -1
    
    git am xxx.patch		# 打补丁
    git apply xxx.patch
    
    #git format-patch详解
    git format-patch HEAD^    	#打包最近的一个patc,有几个^就打包几个patch的内容;或git format-patch -n
    git format-patch -n1 -n2		#打包版本n1与n2之间的patch:
    git format-patch xxx				#某次提交以后的所有patch:,xxx是commit名
    git format-patch -n xxx    	#某次提交(含)之前的几次提交:,xxx是commit名
    git format-patch xxx..xxx 	#某两次提交之间的所有patch:,xxx是commit名
    git format-patch xxx --stdout > xxx.patch	# 将所有patch输出到一个指定位置的指定文件
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    git设置默认vim

    git config --global core.editor vim
    
    • 1

    nano 退出方式
    ctrl+x ,输入y

  • 相关阅读:
    【安全测试】渗透测试神器BurpSuite环境搭建
    Python项目实战 —— 04. 淘宝用户行为分析
    Python数据分析案例07——二手车估价(机器学习全流程,数据清洗、特征工程、模型选择、交叉验证、网格搜参、预测储存)
    Element UI + tree组件 + 面包屑 实现导航
    flutter图文列表
    【内存操作函数内功修炼】memcpy + memmove + memcmp + memset(四)
    前端学习笔记——第三天
    【Linux】服务器间免登陆访问
    点大商城V2_2.5.0 全开源独立版 商家自营+多商户入驻 百度+支付宝+QQ+头条+小程序端+unipp开源前端
    java计算机毕业设计基于安卓Android的校园单车租赁App
  • 原文地址:https://blog.csdn.net/qq_45698138/article/details/133885526
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号