Git入门级常用命令(1)

Git入门级常用命令(1)

话不多说,直接上干货~

入门

下载

https://git-scm.com/downloads

查看版本

$ git --version 
git version 2.30.0.windows.1

常用命令


mkdir oa-parent 
cd oa-parent 
vim .gitignore 
git init 
// 添加文件到暂存区 
git add --all(或 git add .// 提交暂存区文件到本地仓库 
git commit -m "first commit" 
// 设置远程仓库地址 
git remote add origin 
https://gitee.com/ph0211/oa-parent.git 
// 推送本地仓库代码到远程仓库 
git push -u origin master 
// 回滚分支 
git pull 
git reset 4c7ee158
git push -f

配置


// 用户名、邮箱 
git config --global user.name "ph0211" 
git config --global user.email "690574895@qq.com" 
// Windows 下需要禁用 
crlf 自动转换 lf git config --global core.autocrlf false 
// 代理服务器 
git config https.proxy http://xzproxy.cnsuning.com:8080
git config http.proxy http://xzproxy.cnsuning.com:8080

配置文件的三种类型


// 当前项目 
git config window 10 修改文件: 
E:\doc\IdeaProjects\code\.git\config 
// 当前用户 
git config --global 
window 10 修改文件: 
C:\Users\PanHao\.gitconfig 
// 所有用户 
git config --system 
window 10 修改文件: 
D:\dev\Git\etc\gitconfig

Windows 下需要禁用 crlf 自动转换 lf

Windows 中的换行符为 crlf, 而在 Linux 下的换行符为 lf
autocrlf = true:表示要求 git 在提交时将 crlf 转换为 lf,而在检出时将 crlf 转换为 lf
autocrlf = false:表示提交和检出代码时均不进行转换
autocrlf = input:表示在提交时将 crlf 转换为 lf,而检出时不转换

忽略配置

// IntelliJ IDEA 
.idea/ 
*.iml 
// Compiled class file 
target/

增加/删除文件

git add –all 和 git add.的区别

版本导致的差别

(1)1.x 版本
git add all 可以提交未跟踪、修改和删除文件。
git add . 可以提交未跟踪和修改文件,但是不处理删除文件。
(2)2.x 版本
两者功能在提交类型方面是相同的。

所在目录不同导致的差异

(1) git add all 无论在哪个目录执行都会提交相应文件。
(2) git add . 只能够提交当前目录或者它后代目录下相应文件。

分支


// 列出所有本地分支 
git branch 
// 列出所有远程分支 
git branch -r 
// 列出所有本地分支和远程分支 
git branch -a 
// 查看出每个分支当前指向的 
commit object git branch -v 
// 查看已经被合并进当前分支的分支 
git branch --merged 
// 查看没有被合并进当前分支的分支 
git branch --no-merged 
// 删除分支 
git branch -d 
// 强制删除分支 
git branch -D 
// 将本地仓库 master 分支与远程仓库 master 分支关联 
git branch --set-upstream-to=origin/master master

查看信息

// 查看提交历史 
git log --oneline --abbrev-commit --graph

git status查看代码状态

新建文件TestServiceImpl.java(文件状态:Untracked)

(1)执行命令

// 新增 TestServiceImpl.java 文件 
git status

(2)Git Bash 执行结果

PanHao@DESKTOP-1K16GB0 MINGW64 /e/doc/IdeaProjects/oa-parent (master) 
$ git status 
On branch master 
Untracked files: 
(use "git add <file>..." to include in what will be committed) 
oa- auth/src/main/java/com/zhss/oa/auth/service/impl/TestServiceImpl.java 
nothing added to commit but untracked files present (use "git add" to track)

将 TestServiceImpl 文件加入暂存区(文件状态:Staged)

(1)执行命令

git add oa- 
auth/src/main/java/com/zhss/oa/auth/service/impl/TestServiceImpl.java git status

(2)Git Bash 执行结果

PanHao@DESKTOP-1K16GB0 MINGW64 /e/doc/IdeaProjects/oa-parent (master) 
$ git add oa- auth/src/main/java/com/zhss/oa/auth/service/impl/TestServiceImpl.java 
PanHao@DESKTOP-1K16GB0 MINGW64 /e/doc/IdeaProjects/oa-parent (master) 
$ git status 
On branch master 
Changes to be committed: 
(use "git restore --staged <file>..." to unstage)
 new file: oa- auth/src/main/java/com/zhss/oa/auth/service/impl/TestServiceImpl.java

提交 TestServiceImpl 文件到本地仓库(文件状态:Unmodify)

(1)执行命令

git commit -m 'add TestServiceImpl class' 
git status

(2)Git Bash 执行结果


PanHao@DESKTOP-1K16GB0 MINGW64 /e/doc/IdeaProjects/oa-parent (master) 
$ git commit -m 'add TestServiceImpl class' 
[master 34806f4] add TestServiceImpl class 
1 file changed, 8 insertions(+) 
create mode 100644 oa- auth/src/main/java/com/zhss/oa/auth/service/impl/TestServiceImpl.java 

PanHao@DESKTOP-1K16GB0 MINGW64 /e/doc/IdeaProjects/oa-parent (master) 
$ git status 
On branch master 
nothing to commit, working tree clean

修改 TestServiceImpl 文件(文件状态:Modified)

(1)执行命令

修改 TestServiceImpl.java 文件 
git status

(2)Git Bash 执行结果

PanHao@DESKTOP-1K16GB0 MINGW64 /e/doc/IdeaProjects/oa-parent (master) 
$ git status 
On branch master 
Changes not staged for commit: 
(use "git add <file>..." to update what will be committed) 
(use "git restore <file>..." to discard changes in working directory) 
       modified: oa- 
auth/src/main/java/com/zhss/oa/auth/service/impl/TestServiceImpl.java 
no changes added to commit (use "git add" and/or "git commit -a")

将 TestServiceImpl 文件加入暂存区(文件状态:Staged)

(1)执行命令

git add oa- 
auth/src/main/java/com/zhss/oa/auth/service/impl/TestServiceImpl.java 
git status

(2)Git Bash 执行结果

PanHao@DESKTOP-1K16GB0 MINGW64 /e/doc/IdeaProjects/oa-parent (master) 
$ git add oa- 
auth/src/main/java/com/zhss/oa/auth/service/impl/TestServiceImpl.java 

PanHao@DESKTOP-1K16GB0 MINGW64 /e/doc/IdeaProjects/oa-parent (master) 
$ git status 
On branch master Changes to be committed: 
	(use "git restore --staged <file>..." to unstage) 
	modified: oa- 
auth/src/main/java/com/zhss/oa/auth/service/impl/TestServiceImpl.java

提交 TestServiceImpl 文件到本地仓库(文件状态:Unmodify)

(1)执行命令

git commit -m 'add a method for TestServiceImpl' 
git status

(2)Git Bash 执行结果

PanHao@DESKTOP-1K16GB0 MINGW64 /e/doc/IdeaProjects/oa-parent (master) 
$ git commit -m 'add a method for TestServiceImpl' 
[master 89362c4] add a method for TestServiceImpl 
1 file changed, 4 insertions(+) 

PanHao@DESKTOP-1K16GB0 MINGW64 /e/doc/IdeaProjects/oa-parent (master) 
$ git status 
On branch master nothing to commit, working tree clean

git log查看提交历史

查看提交历史

git log

(1)执行命令

git log

(2)Git Bash 执行结果

PanHao@DESKTOP-1K16GB0 MINGW64 /e/doc/IdeaProjects/oa-parent (master) 
$ git log 
commit 89362c4377ea82f11103f07b2bcbd0f260e122cc (HEAD -> master) 
Author: ph0211 <690574895@qq.com> 
Date: Thu Jan 28 00:09:40 2021 +0800 
	add a method for TestServiceImpl 
commit 34806f4563e114dbc82a78f66ee6588f9c0fc24b 
Author: ph0211 <690574895@qq.com> 
Date: Wed Jan 27 23:49:17 2021 +0800 
	add TestServiceImpl class 
commit 137d1e64ee796aead7664f6ecc433d8c560d04e8 
Author: ph0211 <690574895@qq.com> 
Date: Wed Jan 27 23:41:32 2021 +0800 
	first commit
git reflog

(1)执行命令

git reflog

(2)Git Bash 执行结果

PanHao@DESKTOP-1K16GB0 MINGW64 /E/doc/IdeaProjects/oa-parent (master) 
$ git reflog 
34806f4 (HEAD -> master) HEAD@{
   0}: reset: moving to HEAD^ 
89362c4 HEAD@{
   1}: commit: add a method for TestServiceImpl 
34806f4 (HEAD -> master) HEAD@{
   2}: commit: add TestServiceImpl class 
137d1e6 HEAD@{
   3}: commit (initial): first commit

查看精简图形结构的提交历史

(1)执行命令

git log --oneline --abbrev-commit --graph 
--oneline 或 --pretty=oneline:以精简模式显示 
–abbrev-commit:头部数据减少 
–graph:图形

(2)Git Bash 执行结果
在这里插入图片描述

重置版本

(1)执行命令

git reset --hard 89362c4:回退到指定版本 
git reset --hard HEAD^:回退到上一个版本 
git reset --hard HEAD~5:回退到倒数第5个版本 

HEAD:就是回退到当前版本 
HEAD^:回退到上一版本 
--hard:恢复工作区、暂存区
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/100706.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • goland 2022.01 激活【2022最新】

    (goland 2022.01 激活)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html1TCF2R91JZ-eyJsaWNlbnNlSWQi…

    2022年3月31日
    725
  • checking for ZTS… configure: error: pthreads requires ZTS, please re-compile PHP with ZTS enabled

    checking for ZTS… configure: error: pthreads requires ZTS, please re-compile PHP with ZTS enabled

    2022年2月17日
    53
  • makefile从入门到放弃——博主吐血整理的笔记

    makefile从入门到放弃——博主吐血整理的笔记本文主要总结了makefile的相关知识点,包括makefile的简介、变量的使用、makefile的基本结构、如何编写一个makefile等基础知识。同时也包括makefile的隐含规则、VPATH等高级知识来优化一个makefile文件,让makefile文件更加简洁。同时文中重点标注了makefile的使用注意事项和makefile嵌套的相关知识。

    2022年6月5日
    82
  • 深圳IT外包公司名单汇总

    深圳IT外包公司名单汇总开科唯识汉克时代拓维云创旭阳软件赛意信息金证股份博颜科技得逸信息新致软件兴融联通通互联信必优易宝长亮科技紫川软件文思海辉东软睿服科技拓保软件联龙汉克润和三丈信息信达体育文化京北方佰钧成亿达新致华云信息纬创软件合生科技海万信息Pactura维沃法本德科中软国际软通动力大展科技天阳博奥特先进数通融安易立德人瑞云盈网络中科软科锐国际湃腾点点新致煜象科技泛鹏天地…

    2022年6月3日
    99
  • Windows端口被占用_windows如何打开端口

    Windows端口被占用_windows如何打开端口电脑系统为Windows10一以管理员身份打开命令行窗口【Win+R】:使用快捷键打开“运行”窗口输入【cmd】,点击确定,打开“命令”窗口二查看被占用端口对应的PID比如在开发时,系统提示你1080已被占用,我们首先要做的就是找到1080端口对应的PID。在命令行中输入命令:netstat-aon|findstr”1080″回车执行命令后,最后一位数字就是被占用窗口的PID。我这里对应的是16996和18912。三查看指定PID的进程在命令行中输入命令:ta.

    2025年9月26日
    3
  • html下划线 下移,css如何实现下划线滑动效果

    html下划线 下移,css如何实现下划线滑动效果本文主要讲述两种下划线动效效果,第一种悬停时X轴由内向外展开实现动画效果,第二种为左右自动展示,由左向右,或由右向左。实现的主要效果是利用伪类标签,以及hover,利用transfrommtrition实现动画效果。x轴由内向外展开利用贝塞尔曲线利用横线的动画实现,具体代码如下:ul{display:flex;padding:0;margin:0;list-style-type:non…

    2022年5月28日
    54

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号