版本控制-git

基础知识与常用命令

|------------------|---|---|
| GIT |||
| 认识git | C语言写的分布版本控制系统 ||
| 安装 | sudo apt-get install git ||
| 配置 | git config --global user.name "I" ||
| 初始化版本库 | git init ||
| 常用命令 |||
| 查看状态 | git status ||
| 查看修改 | git diff ||
| 将修改添加到暂存区 | git add XX ||
| 将暂存区内容提交至版本库 | git commit -m "message" ||
| 查看提交日志 | git log 、git reflog->记录你操作过的命令 ||
| 版本回退 | git reset HEAD^ ||
| 丢弃修改 | git checkout -- file 丢弃工作区的修改 ||
| 删除 | git rm file 想要恢复用checkout ||
| 添加远程仓库 | git remote add origin github...... 关联远程仓库 ||
| 推送修改 | git push origin 'brach' ||
| 查看远程仓库 | git remote -v ||
| 克隆仓库 | git clone 'url' 支持https/ssh ||
| 删除远程 | git remote -v 解除远程绑定 ||
| 分支与标签 |||
| 创建并切换分支 | git checkout -b <name> /git swithc -c <name>, 也可分步执行 ||
| 查看/删除分支 | git branch 当前工作分支*标记 git branch -d <name> -D 强删 ||
| 合并分支 | git checkout master git merge dev 将dev合并到master ||
| 合并冲突 | 以<<<< ====== >>>> 标记出不同分支的修改 ||
| stash暂存 | 暂存->git stash 恢复-> git stash appy 删除暂存->git stash drop。 或者 git stash pop ||
| 获取远程最新 | git pull ||
| 合并提交 | git rebase ||
| 新建标签 | git tag <name> 默认HEAD,也可指定commit id ||
| 指定标签信息 | git tag -a <name> -m "message" ||
| 查看标签 | git tag ||
| 删除标签 | git tag -d <name> 再推送git push origin:refs/tags/<tag> 删除远程标签 ||
| 推送本地标签 | git push origin <name> / --tags(推送所有未推送过的标签) ||
| 自定义git |||
| 改显示颜色 | git config --global color.ui true ||
| 忽略特殊文件 | 编写 .gitignore ||
| 别名 | git status <=> git config --global alias.st status ||

更多细节

1、git reset

|-----------|---|---|
| 版本回退参数 git reset --hard/soft/mixed |||
| hard | 后面跟commitID回退指定版本 ||
| soft | 回退指定版本未提交状态 git add但没有git commit ||
| mixed | 回到上次已修改没有添加修改, 没有git add 和git commit ||

2、git log

|-----------|---|---|
| 简洁模式 | git log --oneline 每个提交显示一行包括commit id和提交信息 ||
| 图形视图 | --graph 以图形方式展示分支和合并历史 ||
| 格式化输出 | --pretty=format:"format" ||
| 搜索 | --grep=<pattern> ||

3、工作区、暂存区(index)、版本库

工作区 :你项目所在的文件夹目录。
暂存区 :用于存储工作区中添加上来的变更(新增、修改、删除)的文件的地方。操作时,使用`git add .`会将本地所有新增、变更、删除过的文件的情况存入暂存区中。
版本库:工作区有一个隐藏目录`.git`,这个不算工作区,而是Git的版本库。版本库里存了很多东西,其中最重要的是称为`stage`(或者叫`index`)的暂存区,还有Git为我们自动创建的第一个分支`master`,以及指向`master`的一个指针叫`HEAD`。

4、杂项

--global 设置后是本地环境所有git 仓库, 没有加这个参数就是只对本仓库有效, git config --global --list查看全局所有配置

git是跟踪修改不是跟踪文件的。git pull 从远程仓库更新并自动合并到当前分支。 git fetch就是获取更新但是不自动合并。

git中的文件四种状态: 未跟踪、已暂存、已修改、已提交

相关推荐
Young_Gnay11 小时前
在学校和工作中遇到的一些git用法
git
一路向北_Coding11 小时前
Git系列之关联远程仓库
git·github
最好结果12 小时前
GitHub fork仓库同步原仓库tags(标签)的详细教程
git·github
周杰伦_Jay13 小时前
【Git操作详解】Git进行版本控制与管理,包括分支,提交,合并,标签、远程仓库查看
大数据·ide·git·科技·分类·github
XXX-X-XXJ14 小时前
二:RAG 的 “语义密码”:向量、嵌入模型与 Milvus 向量数据库实操
人工智能·git·后端·python·django·milvus
少女续续念15 小时前
从工具到生态:揭秘 Gitee 成为 60% 头部银行首选的底层逻辑
git
银安18 小时前
Git篇(6):分支操作的本质
git
银安18 小时前
Git篇(7):Git 检测差异的原理——为什么合并会出现冲突
git
马优晨20 小时前
Git 中的某个分支打标签
git·git 中的某个分支打标签·git分支打标签·git 分支打tag·git 分支打标签tag
Blue桃之夭夭20 小时前
git和VScode
ide·git·vscode