git 常用命令

本文围绕Git展开,介绍了使用分支开发、克隆项目、解决换行符问题、迁移仓库等操作,还阐述了Git本地数据管理的三个区:工作区、暂存区和版本库,以及各区间数据传递流程。此外,详细讲解了git stash相关命令的使用,最后提及解决vscode输入账号密码的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用分支进行开发

以当前代码为基础创建并切换分支,推送分支到资源库
git checkout -b report

git push --set-upstream origin report

git clone submodule项目

git clone 主项目

git submodule init
git submodule update

创建新的分支

git checkout -b formview

切换到主分支:

首先

git checkout -b temp

其次

git checkout master

解决window换行符提示出错问题:

git config --global core.autocrlf input

git迁移仓库

把原来仓库内容获取出来
git clone --bare https://gitee.com/zhy6599/cc-admin-api.git
git clone --bare https://gitee.com/zhy6599/cc-admin-web.git

推送到新仓库
cd cc-admin-api.git
git push --mirror http://gitee.com/zhy6599/platform/quasar-api.git


cd cc-admin-web.git
git push --mirror http://gitee.com/zhy6599/platform/quasar-web.git
window下迁出代码后提示:Expected linebreaks to be 'LF' but found 'CRLF' 

管理员身份运行cmd

git config --global core.autocrlf input

放弃本地更改,将文件强制更新到服务器最新版本

git fetch --all
git reset --hard origin/master


说明:git fetch 只是下载远程的库的内容,不做任何的合并 git reset 把HEAD指向刚刚下载的最新的版本

git clean -df 
删除当前目录下没有被track过的文件和文件夹

git clean -xf

删除当前目录下所有没有track过的文件. 不管他是否是.gitignore文件里面指定的文件夹和文件

git reset --hard
git clean -f 
结合使用他们能让你的工作目录完全回退到最近一次commit的时候

查看历史提交信息,并将代码回滚到指定版本

git log -3
git reset --hard 832fbe05c333c47bd1c2a766946103791f10c4ed

git push -f

在.git 文件夹同级目录建立文件 .gitignore   用来忽略掉不应该提交的代码

# maven ignore
target/
!.mvn/wrapper/*
*.war
*.zip
*.tar
*.tar.gz


# eclipse ignore
.settings/
.project
.classpath

# idea ignore
.idea/
*.ipr
*.iml
*.iws
.iml

# temp ignore
logs/
*.log
*.log*
*.log.*
*.cache
*.diff
*.patch
*.tmp


# system ignore
.DS_Store
Thumbs.db

git 分支操作命令

查看服务器端所有分支
git branch -a


查看本地分支
git branch

创建本地分支
git branch 分支名称

把本地分支和远程分支之间建立关联,然后才能push
git push --set-upstream origin 分支名称

强制推送:如果之前已经推送过一次,但是推送失败了,可以使用 git push --force origin dev 强制推送。
git push --force origin dev


将指定分支合并到当前分支
git merge [branch-name]


删除本地分支
git branch -d 

从远程仓库拉取更新到本地分支。
git pull origin [branch-name]

撤销指定提交
git revert [commit-hash]


重置指定分支到上一个提交状态
git reset [branch-name]


创建并切换到新分支
git checkout -b [new-branch-name]

把服务器端分支拉回来
git pull


本地切换到另外一个分支
git checkout 分支名

git 记住账号和密码

git config --global credential.helper store

CR、LF、CR/LF为不同操作系统上使用的换行符:

  • Windows/DOS系统:采用CR/LF表示下一行;
  • Unix/Linux系统:采用LF表示下一行;
  • Mac OS系统:采用CR表示下一行;
  • Mac OS X系统:采用LF表示下一行(Mac OS X已经改成和Unix/Linx一样使用LF)。
  • Git默认在提交时将Windows换行符(CRLF)转换为LF,在拉取时将UNIX换行符(LF)替换成CRLF。

  • 为了保持代码一致,政务项目统一使用 LF 作为唯一换行符。

git 配置

  1. 关闭换行符自动转换功能

    // 提交检出均不转换
    git config --global core.autocrlf false
  2. 开启换行符检查功能

    // 拒绝提交包含混合换行符的文件
    git config --global core.safecrlf true
    
    // 允许提交包含混合换行符的文件
    git config --global core.safecrlf false
    
    // 提交包含混合换行符的文件时给出警告
    git config --global core.safecrlf warn

以下内容出自:https://www.jianshu.com/p/f79ae362ef9e

Git 可以大概分为三个区

Git 本地数据管理,大概可以分为三个区,工作区,暂存区和版本库。

  • 工作区(Working Directory)
    是我们直接编辑的地方,例如 Android Studio 打开的项目,记事本打开的文本等,肉眼可见,直接操作。
  • 暂存区(Stage 或 Index)
    数据暂时存放的区域,可在工作区和版本库之间进行数据的友好交流。
  • 版本库(commit History)
    存放已经提交的数据,push 的时候,就是把这个区的数据 push 到远程仓库了。

下面是,当开发者通过 git 修改数据时,各区之间的数据传递流程示意图。

为了验证以上流程的正确性,我们可以自己动手实验一下,为了对比三个区之间的数据差别,过程中,可以借助神奇的 diff 命令。

命令作用
git diff工作区 vs 暂存区
git diff head工作区 vs 版本库
git diff --cached暂存区 vs 版本库

命令作用
git reset --soft暂存区->工作区
git reset --mixed版本库->暂存区
git reset --hard版本库->暂存区->工作区

原文链接:https://blog.youkuaiyun.com/stone_yw/article/details/80795669
1 git stash
能够将所有未提交的修改(工作区和暂存区)保存至堆栈中,用于后续恢复当前工作目录。


2 git stash save
作用等同于git stash,区别是可以加一些注释 
 
3 git stash list
查看当前stash中的内容


4 git stash pop
将当前stash中的内容弹出,并应用到当前分支对应的工作目录上。
注:该命令将堆栈中最近保存的内容删除(栈是先进后出)

5 git stash apply
将堆栈中的内容应用到当前目录,不同于git stash pop,该命令不会将内容从堆栈中删除,也就说该命令能够将堆栈的内容多次应用到工作目录中,适应于多个分支的情况。

6 git stash drop + 名称
从堆栈中移除某个指定的stash

7 git stash clear
清除堆栈中的所有 内容

8 git stash show
查看堆栈中最新保存的stash和当前目录的差异。
通过 git stash show -p 查看详细的不同

9 git stash branch
从最新的stash创建分支。
应用场景:当储藏了部分工作,暂时不去理会,继续在当前分支进行开发,后续想将stash中的内容恢复到当前工作目录时,如果是针对同一个文件的修改(即便不是同行数据),那么可能会发生冲突,恢复失败,这里通过创建新的分支来解决。可以用于解决stash中的内容和当前目录的内容发生冲突的情景。
发生冲突时,需手动解决冲突。
 


vscode git 总提示输入账号密码,在仓库根目录输入命令然后拉取下,输入账号密码,重启vscode

git config --global credential.helper store

<think>我们被要求生成一个关于Git常用命令的汇总列表。根据用户的要求,我们需要提供结构清晰的回答,并尽量保证真实可靠。同时,我们参考了站内引用中提供的Git命令信息。根据引用内容,我们可以整理出以下常用命令:1.基本操作(初始化、添加、提交等)2.分支管理3.远程仓库操作4.标签管理5.历史查看与撤销6.其他实用命令(如删除大文件、清理仓库等)我们将按照这些类别来组织命令。注意:由于引用中提供了一些特定问题的解决方案(如删除大文件),我们也会将其作为实用命令的一部分。另外,注意用户要求使用中文回答,并且行内数学表达式使用$...$格式(但本问题不涉及数学表达式,所以忽略),独立公式使用$$...$$格式(同样不涉及)。同时,在回答末尾生成相关问题。我们开始整理Git常用命令汇总:</think>### Git常用命令汇总 以下是Git常用命令分类整理,帮助您高效管理代码版本: #### 1. 仓库初始化与基础操作 ```bash # 初始化新仓库 $ git init # 克隆远程仓库 $ git clone <远程仓库URL> # 查看当前状态 $ git status # 添加文件到暂存区 $ git add <文件名> # 添加单个文件 $ git add . # 添加所有修改 # 提交更改 $ git commit -m "提交说明" ``` #### 2. 分支管理 ```bash # 创建分支 $ git branch <新分支名> # 切换分支 $ git checkout <分支名> $ git switch <分支名> # Git 2.23+推荐方式 # 创建并切换分支 $ git checkout -b <新分支名> $ git switch -c <新分支名> # 合并分支 $ git merge <要合并的分支名> # 删除分支 $ git branch -d <分支名> # 安全删除 $ git branch -D <分支名> # 强制删除未合并分支 ``` #### 3. 远程仓库操作 ```bash # 添加远程仓库 $ git remote add origin <远程仓库URL> # 查看远程仓库 $ git remote -v # 推送到远程仓库 $ git push -u origin <分支名> # 首次推送 $ git push # 后续推送 # 拉取远程更新 $ git pull origin <分支名> $ git pull --rebase origin <分支名> # 变基式拉取 # 删除远程连接 $ git remote rm origin ``` #### 4. 版本回退与撤销 ```bash # 查看提交历史 $ git log $ git log --oneline # 简洁版日志 # 撤销工作区修改 $ git checkout -- <文件名> # 撤销暂存区文件 $ git reset HEAD <文件名> # 版本回退 $ git reset --hard <commit_id> # 彻底回退 $ git reset --soft <commit_id> # 保留修改 # 恢复删除的文件 $ git restore <文件名> # Git 2.23+ ``` #### 5. 标签管理 ```bash # 查看标签 $ git tag # 创建标签 $ git tag <标签名> # 轻量标签 $ git tag -a v1.0 -m "版本说明" # 附注标签 # 推送标签 $ git push origin <标签名> # 删除标签 $ git tag -d <标签名> # 本地删除 $ git push origin :refs/tags/<标签名> # 远程删除 ``` #### 6. 高级维护 ```bash # 清理历史大文件 $ git filter-branch --force --index-filter \ 'git rm -rf --cached --ignore-unmatch <文件名>' \ --prune-empty --tag-name-filter cat -- --all # 回收存储空间 $ git reflog expire --expire=now --all $ git gc --prune=now # 查看仓库大小 $ git count-objects -vH ``` #### 7. 配置相关 ```bash # 设置用户名/邮箱 $ git config --global user.name "用户名" $ git config --global user.email "邮箱" # 查看配置 $ git config --list # 设置默认编辑器 $ git config --global core.editor vim ``` > **最佳实践提示**: > 1. 频繁提交小变更,保持提交记录清晰 > 2. 使用`.gitignore`文件排除无需版本控制的文件 > 3. 重要分支(如main/prod)设置保护规则 > 4. 推送前先执行`git pull --rebase`避免合并提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值