git工作中常用的命令

2023-05-16

注意修改了这些config后,需要exit后才能生效
git config --global core.editor "vim" 
git config --global alias.co checkout
git config --global alias.ci commit
git config --global alias.st status
git config --global alias.br branch
git config --global alias.hist 'log --graph --format=format:"%C(red)%h%C(reset) %C(yellow)%ad%C(reset) | %s %C(green)\[%an\]%C(reset)%C(bold blue)%d%C(reset)" --abbrev-commit --date=short'
git config --global alias.root 'rev-parse --show-toplevel'
git config --global alias.alias '!git config --global --list | grep ^alias'
git config --global alias.head 'rev-list -n1 --abbrev-commit HEAD' 
git config --global color.ui auto  

git config --global -l   可以查看我的配置


$ git checkout -b dev   #Switched to a new branch 'dev'
git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:

$ git branch dev    #创建 branch dev
$ git checkout dev  #Switched to branch 'dev'
$ git branch命令会列出所有分支,当前分支前面会标一个*号。

$ git add readme.txt 
$ git commit -m "branch test"
现在,dev分支的工作完成,我们就可以切换回master分支:
$ git checkout master  #Switched to branch 'master'
$ git merge dev  #把dev分支的工作成果合并到master分支上

git checkout -- file可以丢弃工作区的修改
git merge命令用于合并指定分支到当前分支。合并后,再查看readme.txt的内容,就可以看到,和dev分支的最新提交是完全一样的。

注意到上面的Fast-forward信息,Git告诉我们,这次合并是“快进模式”,也就是直接把master指向dev的当前提交,所以合并速度非常快。

当然,也不是每次合并都能Fast-forward,我们后面会讲其他方式的合并。

合并完成后,就可以放心地删除dev分支了:

$ git branch -d dev   #Deleted branch dev.
删除后,查看branch,就只剩下master分支了:
$ git branch
* master
因为创建、合并和删除分支非常快,所以Git鼓励你使用分支完成某个任务,合并后再删掉分支,这和直接在master分支上工作效果是一样的,但过程更安全。

Git鼓励大量使用分支:

查看分支:git branch

创建分支:git branch <name>

切换分支:git checkout <name>

创建+切换分支:git checkout -b <name>

合并某分支到当前分支:git merge <name>

删除分支:git branch -d <name>
注意:切换分支前需要提交修改的代码,然后再切换分支,不然会丢失工作区代码修改
$ git add readme.txt 
$ git commit -m "branch test"


$ git add test.txt
$ git commit -m "add test.txt"
提交了过后再删除文件这样,如果没有提交可以直接rm file来删除添加的文件
$ git rm test.txt删除文件
$ git commit -m "remove test.txt"#把删除的提交上去

git log --graph命令可以看到分支合并图
git log --graph --pretty=oneline --abbrev-commit   

gitk
在gerrit上如何cherry pick代码


--------[cherry-pick]---------------------
 
git cherry-pick <commit id>
 
------------<cherry-pick Conflict>-------------------
git mergetool
git cherry-pick --continue  
 

cherrypick 相关的命令
------------[rebase Conflict]--------------------
git mergetool
git rebase --continue  

# 删除 untracked files
git clean -f
# 连 untracked 的目录也一起删掉
git clean -fd
# 连 gitignore 的untrack 文件/目录也一起删掉 (慎用!一般这个是用来删掉编译出来的 .o之类的文件用的)
git clean -xfd
# 在用上述 git clean 前,建议加上 -n 参数来先看看会删掉哪些文件,防止重要文件被误删
git clean -nxfd
git clean -nf
git clean -nfd


--------[cherry-pick]---------------------

git cherry-pick <commit id>

----------- [ set yoursream: Master ]---------------------
git br --set-upstream-to origin/master

--------[ git show ]---------------------
git show <commit-id>

--------[ untracked files ]---------------------

git clean -f 

--------[ untracked ]---------------------

git clean -fd 

--------[ gitignore  untrack ]---------------------

git clean -xfd 

  

--------[ git clean ]---------------------

git clean -nxfd 

git clean -nf 

git clean -nfd


--------[hard commit-id]---------------------

git reset --hard commit-id

??:git reset --hard ca50b7be070

--------[revert commit]---------------------

git revert <commit-id>

git revert ca50b7be070


--------[update]---------------------
git reset HEAD^
git co commit-id
git co -b xxxxx
git st

git hist #可以查看提交历史,提交序列号

git show 7a197535ebc --name-only   看这个版本提交了什么文件

git show 7a197535ebc tools/scripts/misc/coding_guidelines_checker.py

 

 

第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;

第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。

 

场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file

场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD <file>,就回到了场景1,第二步按场景1操作。

场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。

 

git reset --soft HEAD^

git log -5

commit    xxxxxxxxxxxxxxx  会看到这行ID号

git reset --hard commit_id //退到/进到 指定commit的sha码

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

git工作中常用的命令 的相关文章

  • 什么情况下需要建立索引? 索引的作用?为什么能够提高查询速度?(索引的原理) 索引有什么副作用吗?

    https www cnblogs com Berryxiong p 6249427 html 为什么能够提高查询速度 xff1f 索引就是通过事先排好序 xff0c 从而在查找时可以应用二分查找等高效率的算法 一般的顺序查找 xff0c
  • 100w测试数据,为什么加了索引查询反而变慢了?

    建表 xff1a create table tb test fval varchar 50 插入测试数据 xff1a DELIMITER CREATE DEFINER 61 96 root 96 64 96 localhost 96 PRO
  • linux环境下使用gdb调试c和c++ 学习笔记

    第二十三课 xff1a GDB简介 哔哩哔哩 bilibili gdb调试 xff1a 1 gcc a c b c c c o app g g 编译器会保留函数名和变量名 2 启动gdb gdb 可执行程序的名字 xff08 gdb app
  • ubuntu下eth0网卡信息不见了

    ubuntu终端下命令ifconfig的问题解决 问题一 ifconfig之后只显示lo 没有看到eth0 问题二 ifconfig之后显示eth0 xff0c 但是没有显示静态IP地址 xff0c 即无inet 地址 广播 掩码 问题三
  • 计算机指令

    指令系统的设计原则包括 xff1a 完备性 xff1a 该有的都要有 有效性 xff1a 简洁 加速常用操作 没有歧义 规整性 xff1a 对称 均匀 一致 xff08 简单源于规整 xff09 兼容性 xff1a 之前 之后的都能用 下面
  • shell基础学习笔记1

    shell是什么 xff1f shell是一个命令解释器 xff0c 他为用户提供了一个向linux内核发送请求以便运行程序的界面系统级程序 xff0c 用户可以用shell来启动 挂起 停止甚至编写一些程序 其实就是输入命令的那个交互界面
  • linux达人养成学习笔记1

    2 4 分区之分区设备文件名与挂载 1 swap分区 xff0c 没有挂载点 xff0c 是文件系统类型 xff08 交换分区 xff0c 电脑内存 lt 4G xff0c 可分为内存2倍 xff1b gt 4G分同等大小 xff09 2
  • shell编程之变量学习小结

    在Bash中 xff0c 变量的默认类型都是字符串型 变量的分类 1 用户自定义变量 xff1a 变量可以自定义 xff0c 但是对系统生效的环境变量名和变量作用是固定的 2 环境变量 xff1a 这种变量中主要保存的是和系统操作环境相关的
  • 程序员的自我修养

    1 Provide Options Don 39 t make lame Excuses 提供各种选择 xff0c 不要找蹩脚的借口 2 Don 39 t live with Broken Windows 不要容忍破窗户 3 Be a ca
  • 二阶三阶四阶魔方旋转公式

  • 什么是回调函数?

    为了弄明白这种函数的奥妙 xff0c 首先提出三个问题 xff1a 1 回调函数是什么东西 xff1f 2 回调函数怎么开发 xff0c 怎么使用 xff1f 3 回调函数的作用 xff0c 应该在什么情况下使用 xff1f 带着问题来学习
  • Toastmasters会议小结

    第四战队第二次会议记录 舰队分享 P1 Ice Breaker Speech 分享人 xff1a 邱爱珍 爱珍结合自己的P1演讲经验 xff0c 从以下五个方面给出相应的意见 Book time to start 尽早在系统中预约自己的第一
  • 如何做好自己的时间管理

    认识时间障碍掌握时间管理的原则掌握各种有效管理隔个人时间的工具 没有目标谈什么时间管理 xff1f xff1f xff1f 今天需要完成的事情 这个周需要完成的事情 这个月需要完成的事情 时间管理的错误观念 时间管理只是常识 xff0c 只
  • 参考别人的面试总结:linux C/C++服务器后台开发面试题总结

    参考别人的面试总结 xff1a linux C C 43 43 服务器后台开发面试题总结 参考博客 xff1a http www cnblogs com nancymake p 6516933 html 基础语言知识方面 xff1a 1 使
  • 常用Git命令

    查看文件当前状态 xff1a git status 查看文件提交信息 xff1a git log 将未被追踪的文件 xff08 工作区 xff09 提交至暂存区 xff1a git add 文件名 所有修改的文件提交至暂存区 xff1a g
  • 直接插入排序算法实现学习

    include lt iostream gt using namespace std void show int a int n for int i 61 0 i lt n i 43 43 cout lt lt a i lt lt 34 t
  • 基本的排序算法C++实现(插入排序,选择排序,冒泡排序,归并排序,快速排序,最大堆排序,希尔排序)

    动图演示 xff1a https www cnblogs com onepixel articles 7674659 html 冒泡排序 include lt bits stdc 43 43 h gt 偷懒的写法 xff0c 不过编译时间比
  • 二分查找法和使用二分法查找的注意事项

    使用二分法查找的必要条件 xff1a 1 数组有序 2 注意数据类型是有范围的 xff0c 不要溢出 3 采用L 43 R L 2表达式更合适 4 注意 xff1a start 61 mid 43 1 和 end 61 mid 1 防止死循
  • 使用程序写出求出1!+2!+...+64!的运算结果。考虑溢出的问题

    求10的阶乘的和 int n 61 10 int num1 61 1 int num2 61 1 for int i 61 1 i lt 61 n i 43 43 num1 61 1 for int j 61 2 j lt 61 i j 4
  • STL中vector的使用

    作用 xff1a 它能够像容器一样存放各种类型的对象 xff0c 简单地说 xff0c vector是一个能够存放任意类型的动态数组 xff0c 能够增加和压缩数据 vector在C 43 43 标准模板库中的部分内容 xff0c 它是一个

随机推荐