• Git常用命令总结


    在平时开发中,Git成为必不可少的版本控制工具,但命令太多,并不能把所有的命令记住,结合网上的一些信息,总结了一些常用的,慢慢熟悉吧。

    初始化命令


    查看当前git配置信息

    # 显示当前Git配置
    $ git config --list

    设置git用户信息

    # 设置提交代码时的用户信息
    $ git config [--global] user.name "[name]"
    $ git config [--global] user.email "[email address]"

    初始化项目

    # 在当前目录新建一个Git代码库
    $ git init

    克隆远程仓库代码,url为仓库地址

    # 下载一个项目和它的整个代码版本(但不包含分支,需手动新建分支关联,后面分支会提到)
    $ git clone [url]

    关联远程库,url为仓库地址

    #与远程仓库关联,也可以直接clone后自动关联
    $ git remote add origin [url]

    增删命令


    添加指定文件

    # 添加指定文件到仓库暂存区,可以指定多个文件用空格隔开
    $ git add [file1] [file2] ...
    # 例子
    $ git add name1.txt name2.txt name3.txt

    添加指定目录

    # 添加指定目录到暂存区,包括子目录
    $ git add [dir]

    添加当前目录下所有文件

    # 添加当前目录的所有文件到暂存区
    $ git add .

    删除指定文件

    # 删除工作区文件,并且将这次删除放入暂存区
    $ git rm [file1] [file2] ...

    删除文件与仓库断开关联

    # 停止追踪指定文件,但该文件会保留在工作区
    $ git rm --cached [file]

    文件改名

    # 改名文件,并且将这个改名放入暂存区
    $ git mv [file-original] [file-renamed]
    # 例子
    $ git mv oldName.txt newName.txt

    显示信息命令

    查看暂存区状态

    # 查看git本地仓库当前状态
    $ git status

    查看暂存区修改情况

    # 查看暂存区文件与仓库文件之间的不同修改
    $ git diff

    查看git日志

    # 查看git详细日志,包含不同版本提交、时间、作者(前面配置email和name这里会有用)
    $ git log
    # 查看简洁化日志 只显示commit信息
    $ git log --pretty=oneline

    查看命令记录

    # 查看命令记录,回退版本时可根据命令编号来
    $ git reflog

    暂存区域最新commit的差异

    # 显示暂存区和最新commit的差异
    $ git diff --cached [file]

    工作区与最新commit的差异

    # 显示工作区与当前分支最新commit之间的差异
    $ git diff HEAD

    某次提交的变化

    # 显示某次提交的元数据和内容变化
    $ git show [commit]

    提交命令


    提交暂缓区全部,并添加描述

    # 提交暂存区到本地仓库区
    $ git commit -m [message]

    提交暂缓区个别文件,并添加描述

    # 提交暂存区的指定文件到本地仓库区
    $ git commit [file1] [file2] ... -m [message]

    提交工作区修改的文件(不需要看暂存区修改的文件)

    # 提交工作区自上次commit之后的变化,直接提交到本地仓库区,只针对修改后的文件
    # 若出现新的文件,还是需要使用add命令,而不是用这个合成后的命令
    $ git commit -am [message]

    修改上一次的提交描述

    # 如果上一次的commit没有push到远程仓库中,使用如下代码可以修改提交描述
    # 前提是没有修改文件,否则是一次新的添加效果
    $ git commit --amend -m [message]
    #----------------------------------
    #通过vim编辑器来修改提交描述,效果一样
    $ git commit --amend

    分支命令


    显示本地所有分支

    # 列出所有本地分支
    $ git branch

    显示所有远程分支

    # 列出所有远程仓库分支
    $ git branch -r

    列出所有分支

    # 列出所有本地分支和远程分支
    $ git branch -a

    新建分支

    # 新建一个分支,但依然停留在当前分支
    $ git branch [branch-name]

    新建并切换到新分支

    # 新建一个分支,并切换到该分支
    $ git checkout -b [branch]

    切换分支

    # 切换到指定分支,并更新工作区
    $ git checkout [branch-name]

    重命名分支

    # 重命名分支,
    $  git branch -m | -M oldbranch newbranch

    新建本地分支与远程分支关联

    # 新建一个分支,与指定的远程分支建立追踪关系
    $ git branch --track [branch] [remote-branch]

    指定分支与远程分支关联

    # 建立追踪关系,在现有分支与指定的远程分支之间
    $ git branch --set-upstream [branch] [remote-branch]

    与当前分支合并

    # 合并指定分支到当前分支
    $ git merge [branch]

    commit合并当前分支

    # 选择一个commit,合并进当前分支
    $ git cherry-pick [commit]

    删除分支

    # 删除分支
    $ git branch -d [branch-name]

    删除远程分支

    # 删除远程分支
    $ git push origin --delete [branch-name]
    $ git branch -dr [remote/branch]

    标签命令


    列出所有标签

    # 列出所有tag
    $ git tag

    当前commit新建一个标签

    # 新建一个tag在当前commit
    $ git tag [tag]

    指定commit新建一个标签

    # 新建一个tag在指定commit
    $ git tag [tag] [commit]

    删除本地标签

    # 删除本地tag
    $ git tag -d [tag]

    删除远程标签

    # 删除远程tag
    $ git push origin :refs/tags/[tagName]

    查看标签

    # 查看tag信息
    $ git show [tag]

    提交指定标签

    # 提交指定tag到远程仓库
    $ git push [remote] [tag]

    提交所有标签

    # 提交所有tag
    $ git push [remote] --tags

    新建分支指向某个tag

    # 新建一个分支,指向某个tag
    $ git checkout -b [branch] [tag]

    远程同步命令


    取回所有分支(branch)的更新

    # 下载远程仓库的所有变动
    $ git fetch [remote]

    显示所有远程仓库

    # 显示所有远程仓库
    $ git remote -v

    显示某个远程仓库

    # 显示某个远程仓库的信息
    $ git remote show [remote]

    增加一个远程仓库

    # 增加一个新的远程仓库,并命名
    $ git remote add [shortname] [url]

    取回远程仓库的变动,与本地分支合并

    # 取回远程仓库的变化,并与本地分支合并
    $ git pull [remote] [branch]

    推送本地指定分支

    # 上传本地指定分支到远程仓库
    $ git push [remote] [branch]

    推送本地所有分支

    # 推送所有分支到远程仓库
    $ git push [remote] --all

    撤销命令


    撤销工作区文件的修改

    # 让工作区文件回到最近一次git commit或git add时的状态
    $ git checkout [file]

    工作区指定文件恢复到某次提交

    # 恢复某个commit的指定文件到工作区
    $ git checkout [commit] [file]

    工作区所有文件恢复到上一次提交状态

    # 恢复上一个commit的所有文件到工作区
    $ git checkout .

    重置指定的暂存区文件

    # 重置暂存区的指定文件,与上一次commit保持一致,但工作区不变
    #等价于取消add操作
    $ git reset [file]

    重置暂存区与工作区

    # 重置暂存区与工作区,与上一次commit保持一致
    $ git reset --hard

    重置本地仓库版本到某次commit提交,暂存区清空

    # 重置当前分支的指针为指定commit,同时重置暂存区,但工作区不变
    $ git reset [commit]

    重置本地仓库版本和工作区到某次commit提交,暂存区清空

    # 重置当前分支的HEAD为指定commit,同时重置暂存区和工作区,与指定commit一致
    $ git reset --hard [commit]

    重置本地仓库版本到某次commit提交,暂存区和工作区不变

    # 重置当前HEAD为指定commit,但保持暂存区和工作区不变
    $ git reset --keep [commit]
    

      

  • 相关阅读:
    嵌入式Linux的调试技术
    硬件抽象层:HAL
    让开发板发出声音
    android 底层入门开发(二)
    android 底层开发入门(一)
    android驱动开发前的准备(五)
    Android驱动开发前的准备(四)
    Android驱动开发前的准备(三)
    Android驱动开发前的准备(二)
    Android驱动开发前的准备(一)
  • 原文地址:https://www.cnblogs.com/horanly/p/6603647.html
Copyright © 2020-2023  润新知