git命令-笔记_git show current-程序员宅基地

技术标签: 版本控制  git  命令  

1 下载地址

Windows版本:https://git-scm.com/download/win

Git-2.29.1-64-bit.exe 2.29.1

2 相关命令

2.1 基本

git init 初始化代码仓库
git status 查询仓库索引状态
git add <文件名/目录> 添加文件到仓库
git config --global user.email “[email protected]” 配置全局的提交者邮箱
git config --global user.name “Your Name” 配置全局的提交者名字
git commit -m “add component to project " --author=” Your Name < [email protected]>" 提交暂存内容(不带文件名的提交)
git commit somefile 提交修改后的文件(原先已经add/commit过)
git config --global core.editor gedit 设置提交时编辑变更信息的编辑器
git log 查看提交记录
git log --graph --pretty=oneline --abbrev-commit
git show <提交码> 查看某次提交详细的变更信息
git show-branch --more=n 查看简洁的单行提交信息
git diff <提交码> <提交码> 查看两个提交之间的差异
git rm <文件名> 删除文件 (需要进一步git commit)
git rm -r <文件夹> 删除文件夹(需要进一步git commit)
git mv <source文件> <Target文件> 重命名
git clone 创建版本库的符本
git config –l 列出配置
git config –unset 移除设置
git reset ––hard 将版本库和工作目录改变为已知状态
git rev-parse <提交> 查看提交标识

2.2 检出

git checkout HEAD – <文件> 恢复文件的旧版本
git checkout HEAD – <文件夹>恢复文件的旧版本
git checkout <分支名> 检出分支并切换到分支

gitk 版本库的可视化

2.3 分支

git branch 列出分支名
git show-branch 显示分支
git branch <分支> <提交> 创建一个分支,弱不包含提交,则标识从当前分支的HEAD创建一个新的分支
git checkout <分支名> 检出分支
git checkout –b <分支名> 检出新分支,并切换到分支
git branch –d <分支名> 删除分支

2.4 diff

git diff 比较工作目录和索引之间的差异
git diff 显示工作目录和给定提交间的差异
git diff 比较两个提交的差异
git diff --cached 显示索引中的变更和给定提交的变更间的差异

2.5 合并

git merge <分支名> 合并分支

2.6 更改提交

git reset --hard HEAD 把工作目录和索引都还原到git merge命令之前
git reset --hard ORIG_HEAD 若合并并提交后想放弃,则需要使用这条命令进行还原到合并前。Git把原始分支的HEAD 保存在ORIG_HEAD
git reset --soft 将HEAD引用指向给定提交。索引和工作目录的内容保持不变。
git reset --mixed 将HEAD指向给定提交,索引内容也跟着改变以符合给定提交的树结构,但是工作目录中的内容保持不变
git reset --hard将HEAD引用指向给定提交,索引的内容也跟着改变以扶额和给定提交的树结构,工作目录的内容也随之改变以反映给定提交表示的树的状态。
git reset HEAD <文件> 撤回暂存

git reset --mixed HEAD^ 退回上一次提交

git cherry-pick <提交> 在当前分支上应用 给定提交引入的变更。一般合并其他分支上的特定版本的一次变更(如修复某个bug)
git revert <提交> 引入一个新提交来抵消给定提交的影响。常见用途为:如某个提交有缺陷,用来撤销那次提交的变更内容,从而去除那次变更引入的问题。

3 命令选项

3.1 git commit

usage: git commit [] [–] …

-q, --quiet           suppress summary after successful commit
-v, --verbose         show diff in commit message template

Commit message options
-F, --file read message from file
–author override author for commit
–date override date for commit
-m, --message
commit message
-c, --reedit-message
reuse and edit message from specified commit
-C, --reuse-message
reuse message from specified commit
–fixup use autosquash formatted message to fixup specified commit
–squash use autosquash formatted message to squash specified commit
–reset-author the commit is authored by me now (used with -C/-c/–amend)
-s, --signoff add Signed-off-by:
-t, --template
use specified template file
-e, --edit force edit of commit
–cleanup how to strip spaces and #comments from message
–status include status in commit message template
-S, --gpg-sign[=]
GPG sign commit

Commit contents options
-a, --all commit all changed files
-i, --include add specified files to index for commit
–interactive interactively add files
-p, --patch interactively add changes
-o, --only commit only specified files
-n, --no-verify bypass pre-commit and commit-msg hooks
–dry-run show what would be committed
–short show status concisely
–branch show branch information
–ahead-behind compute full ahead/behind values
–porcelain machine-readable output
–long show status in long format (default)
-z, --null terminate entries with NUL
–amend amend previous commit
–no-post-rewrite bypass post-rewrite hook
-u, --untracked-files[=]
show untracked files, optional modes: all, normal, no. (Default: all)
–pathspec-from-file
read pathspec from file
–pathspec-file-nul with --pathspec-from-file, pathspec elements are separated with NUL character

3.2 git checkout

usage: git checkout []
or: git checkout [] [] – …

-b <branch>           create and checkout a new branch
-B <branch>           create/reset and checkout a branch
-l                    create reflog for new branch
--guess               second guess 'git checkout <no-such-branch>' (default)
--overlay             use overlay mode (default)
-q, --quiet           suppress progress reporting
--recurse-submodules[=<checkout>]
                      control recursive updating of submodules
--progress            force progress reporting
-m, --merge           perform a 3-way merge with the new branch*
--conflict <style>    conflict style (merge or diff3)
-d, --detach          detach HEAD at named commit
-t, --track           set upstream info for new branch
-f, --force           force checkout (throw away local modifications)
--orphan <new-branch>
                      new unparented branch
--overwrite-ignore    update ignored files (default)
--ignore-other-worktrees
                      do not check if another worktree is holding the given ref
-2, --ours            checkout our version for unmerged files
-3, --theirs          checkout their version for unmerged files
-p, --patch           select hunks interactively
--ignore-skip-worktree-bits
                      do not limit pathspecs to sparse entries only
--pathspec-from-file <file>
                      read pathspec from file
--pathspec-file-nul   with --pathspec-from-file, pathspec elements are separated with NUL character

3.3 git branch

usage: git branch [] [-r | -a] [–merged] [–no-merged]
or: git branch [] [-l] [-f] []
or: git branch [] [-r] (-d | -D) …
or: git branch [] (-m | -M) []
or: git branch [] (-c | -C) []
or: git branch [] [-r | -a] [–points-at]
or: git branch [] [-r | -a] [–format]

Generic options
-v, --verbose show hash and subject, give twice for upstream branch
-q, --quiet suppress informational messages
-t, --track set up tracking mode (see git-pull(1))
-u, --set-upstream-to
change the upstream info
–unset-upstream unset the upstream info
–color[=] use colored output
-r, --remotes act on remote-tracking branches
–contains print only branches that contain the commit
–no-contains
print only branches that don’t contain the commit
–abbrev[=] use digits to display object names

Specific git-branch actions:
-a, --all list both remote-tracking and local branches
-d, --delete delete fully merged branch
-D delete branch (even if not merged)
-m, --move move/rename a branch and its reflog
-M move/rename a branch, even if target exists
-c, --copy copy a branch and its reflog
-C copy a branch, even if target exists
-l, --list list branch names
–show-current show current branch name
–create-reflog create the branch’s reflog
–edit-description edit the description for the branch
-f, --force force creation, move/rename, deletion
–merged print only branches that are merged
–no-merged print only branches that are not merged
–column[=

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/skytering/article/details/109458773

智能推荐

springboot中的自动装箱原理_springboot自动装箱-程序员宅基地

文章浏览阅读784次,点赞4次,收藏5次。引言:大家在使用springboot的时候不得不感叹它的功能强大和方便,但是作为一个合格的程序员,单纯只是去使用框架是远远不够的!我们知道,Spring Boot 项目创建完成后,即使不进行任何的配置,也能够顺利地运行,这都要归功于 Spring Boot 的自动化配置。Spring Boot 默认使用 application.properties 或 application.yml 作为其全局配置文件,我们可以在该配置文件中对各种自动配置属性(server.port、logging.level._springboot自动装箱

【类脑智能】脑网络通信模型分类及量化指标(附思维导图)-程序员宅基地

文章浏览阅读1k次,点赞16次,收藏30次。脑网络通信模型是一种使用图论和网络科学概念来描述和量化大脑结构中信息传递的模型。这种模型可以帮助研究人员理解神经信号在大脑内部如何传递,并探究不同脑区之间的通信策略。通过将生物神经信号抽象为网络通信动力学,这一理论框架提供了一种灵活方法来模拟相互连接的神经元间相互作用。脑网络通信模型也可以简化解释神经信号,抽象神经动力学的突发性和全系统特性,有助于捕捉大脑结构和功能之间的关系。总的来说,脑网络通信模型是一种基于网络科学和神经科学的框架,用于研究大脑结构和功能之间的信息传递机制。

解决 Echarts 图表在旧容器上重新渲染不出来的问题_echarts渲染div容器后,为什么div里面之前的div元素没了-程序员宅基地

文章浏览阅读2.2k次,点赞2次,收藏7次。今天修改项目时,由于使用了 Echarts 图表库,在原先的基础上,加上了切换tab标签和根据搜索内容重新渲染图表的需求,由于是异步获取数据后更新渲染图表,然后发现图表重新渲染不出来,由此记录下解决问题的过程。问题描述根据异步获取到的数据重新渲染图表,比如 Echarts 容器标签如下:<div id="chartId"></div>当搜索结果没有数据时,输出一段话提示用户:<div id="chartId"> <p>暂无数据</p&g._echarts渲染div容器后,为什么div里面之前的div元素没了

将图片放入数据库中已经从数据库中把图片读出来_图片放在看板数据源中-程序员宅基地

文章浏览阅读2k次。先讨论一下图片放入数据库中。Oracle数据库中的大对象类型有两种: a.Blob二进制的大对象类型,主要是指音频,视频,图像,word等文档,被认为是二进制的文件。 b.Clob字符型的大对象类型,主要是指文本文件。图片是数据库中的Blob大对象类型。如下代码是将一张图片放入数据库中。import java.io.File;import java.i_图片放在看板数据源中

Ceph 0.80 ubuntu14.04 多节点手动搭建_/ceph/mon-a-程序员宅基地

文章浏览阅读1.4k次。之前写了快速搭建ceph的过程,在使用过程中有很多bug,比如……我关不掉ceph,删不掉osd节点等等等等。。。不知道是我哪里出错了,总之感觉不太好,所以快速搭建给我的感觉就是体验一下ceph到底是个什么东西,生产环境里用不了。这里记录一下我手动搭建的过程。搭建环境:Ubuntu14.04Ceph版本,0.80虚拟机搭建,任然是四个节点(mon节点_/ceph/mon-a

Hubble Zhang的学习日记(第十周)_hubble日志-程序员宅基地

文章浏览阅读99次。为了督促自己每天都有进步,在这里记录下每天遇到的问题和学到的新知识,仅作为个人回顾使用。目录日记(第九周)20201120日记(第九周)20201120候选区域R-CNN,意思就是带区域的卷积网络,这个算法尝试选出一些区域,在这些区域上运行卷积网络分类器是有意义的。利用segmentation得到多个分割区域,然后在这些分割区域中跑分类器来检测这个块里是否有东西。R-CNN算法比较慢,因此衍生了许多升级算法,如Fast R-CNN,Faster R-CNN......._hubble日志

随便推点

html5 动态存储 localStorage.name 和localStorage.setItem()的差别_localstorage.setitem('aa')和localstorage.aa一样吗-程序员宅基地

文章浏览阅读1.2w次,点赞2次,收藏3次。localStorage.name=“maoguiyou”和localStorage.setItem("name","maoguiyou")都是和h5本地存储的方法,第一个就不用说了,直接把值赋给name字段,主要是说说第二个,第二个也是里面有两个参数,第一个是字段名,第二个是值,他和第一个的差别就在于他能动态存储数据,例如:for(var i=0;i{localStorage.set_localstorage.setitem('aa')和localstorage.aa一样吗

02.loadrunner之http接口脚本编写_http脚本-程序员宅基地

文章浏览阅读4.8k次,点赞7次,收藏47次。目录一、前言二、创建脚本-http1.通用部分2.POST:application/x-www-form-urlencoded脚本3.POST:application/json脚本4.POST:multipart/form-data脚本5.GET脚本三、函数详解1.lr_start_transaction/lr_end_transaction事务组合2.we..._http脚本

The server time zone value ‘�й���׼ʱ��‘ is unrecognized or represents more than one time zone.-程序员宅基地

文章浏览阅读545次。在spring和mybatis的启动过程中,数据库启动出现异常

如何打造企业短视频账号的人设?_做的比较有人格化的公司短视频账号-程序员宅基地

文章浏览阅读1k次。人都有惰性,更何况是在碎片化的时间里,抱着轻松一下的目的打开了抖音,我们是不愿意浪费精力到“这个抖音号到底是什么类型的,它是否会持续生产我喜欢和需要的内容”这类问题上。所以,我们在做企业抖音号的人设时,如何化繁为简,把账号的人设做成平台受众的人设:账号简介-简练、直白地体现鲜明个性那些点进账号主页看的受众,多半都是被某一个视频吸引进来的。他们进来的目的只有一个:看看这个账号是不是我喜欢的类型,值不值得我去关注。这时,你的那句账号简介,就像面试或相亲时的自我介绍一样,起着营造受众心中第一印象的至关重_做的比较有人格化的公司短视频账号

一个会做饭的程序员如何每天给女朋友带不同的便当?-程序员宅基地

文章浏览阅读343次。作为一个会做饭的程序员,每天给女朋友和自己带饭是必须的,可是每天要吃什么却是一个世纪难题!以前就想过要开发一个APP,来随机决定明天吃什么菜,然而世界上最痛苦的事情是:我..._csdn 给女朋友做菜单

PendingIntent重定向:一种针对安卓系统和流行App的通用提权方法——BlackHat EU 2021议题详解 (下)_getrunningservicecontrolpanel-程序员宅基地

文章浏览阅读8.9k次,点赞4次,收藏10次。以用户隐私安全为中心,用责任兑付信任,OPPO成立子午互联网安全实验室(ZIWU Cyber Security Lab)。实验室以“保护用户的安全与隐私,为品牌注入安全基因”为使命,持续关注并发力于业务安全、红蓝对抗、IoT安全、Android安全、数据和隐私保护等领域。本篇文章源自OPPO子午互联网安全实验室。1 不安全PendingIntent的通用利用方法1.1 不安全PendingIntent的特征至此,我们已经解决了本议题的第一个问题,经过研究表明,Android系统中使用的Pendin._getrunningservicecontrolpanel

推荐文章

热门文章

相关标签