Git(四):Git常用命令

1. 本地库初始化

#初始化本地库
git init

注意:.git 目录中存放的是本地库相关的子目录和文件,不要删除,也不要胡乱修改。

2. 设置签名

  • 形式
    用户名:tom
    Email地址:[email protected]
    
  • 作用:区分不同开发人员的身份
  • 辨析:这里的设置的签名和登录远程库(代码托管中心)的账号、密码没有任何关系。
  • 命令
    • 项目级别/仓库级别:仅在当前本地库范围内有效
       git config user.name test
       git config user.email [email protected]
       # 信息保存位置:./.git/config 文件
      
    • 系统用户级别:登录当前操作系统的用户范围
      git config user.name test
      git config user.email [email protected]
      #信息保存位置:~/.gitconfig 文件
      
    • 级别优先级
      • 就近原则:项目级别优先于系统用户级别,二者都有时采用项目级别的签名;
      • 如果只有系统用户级别的签名,就以系统用户级别的签名为准
      • 二者都没有不允许

3. 基本操作

3.1 状态查看

#查看工作区、暂存区状态
git status

3.2 添加

#将工作区的”新建/修改“添加到暂存区
git add [file name]

3.3 提交

#将暂存区的内容提交到本地库
git commit -m "commit message" [file name]

3.4 查看历史记录

git log
  • 多屏显示控制方式:
    • 空格向下翻页;
    • b 向上翻页;
    • q 退出;
git log --pretty=oneline

git log --oneline

git reflog

HEAD@{移动到当前版本需要多少步}

3.5 前进后退

  • 基于索引值操作【推荐】
    git reset --hard [局部索引值]
    #git reset -- hard a6ace91
    
  • 使用^符号:只能后退
    git reset --hard HEAD^
    #一个 ^ 表示后退一步,n个表示后退n步
    
  • 使用 ~符号:只能后退
    git reset --hard HEAD~n
    #表示后退n步
    

3.6 reset命令的三个参数对比

  • --soft :参数
    • 仅仅在本地库移动 HEAD 指针
  • --mixed :参数
    • 在本地库移动HEAD指针
    • 重置暂存区
  • --hard:参数
    • 在本地库移动 HEAD 指针
    • 重置暂存区
    • 重置工作区

3.7 删除文件并找回

  • 前提:删除前,文件存在时的状态提交到了本地库。
  • 操作:git reset --hard [指针位置]
    • 删除操作已经提交到本地库:指针位置指向历史记录
    • 删除操作尚未提交到本地库:指针位置使用HEAD

3.8 比较文件差异

#将工作区中的文件和暂存区进行比较
git diff [文件名]

#讲工作区中的文件和本地库历史记录比较
git diff [本地库历史版本] [文件名]

#不带文件名比较多个文件

4. 分支管理

4.1 什么是分支

在版本控制过程中,使用多条线同时推进多个任务。
在这里插入图片描述

4.2 分支的好处

  • 同时并行推进多个功能开发,提高开发效率
  • 各个分支在开发过程中,如果一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可。

4.3 分支操作

#创建分支
git branch [分支名]

#查看分支
git branch -v

#切换分支
git checkout [分支名]

#合并分支
#第一步:切换到接收修改的分支(被合并,增加新内容)上
git checkout [被合并分支名]
#第二步:执行merge命令
git merge [有新内容分支名]
  • 解决冲突
    • 冲突的表现
      在这里插入图片描述
  • 冲突的解决
    • 第一步:编辑文件,删除特殊符号
    • 第二步:把文件修改到满意的程度,保存退出;
    • 第三步:git add [文件名]
    • 第四步:git commit -m “日志信息”
      • 注意:此时 commit 一定能带具体文件名

猜你喜欢

转载自blog.csdn.net/houwanle/article/details/112548712
今日推荐