版本控制-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中的文件四种状态: 未跟踪、已暂存、已修改、已提交

相关推荐
zhangfeng11338 分钟前
CodeBuddy ai对话框上面的git docs terminal Rulds 干嘛用的,以thinkphp fastadmin 为例,插件市场
人工智能·git·编程
OYangxf1 小时前
Git Conflict Resolution
大数据·git·elasticsearch
高斯林.神犇1 小时前
Git全套流程
git
次元工程师!3 小时前
LangFlow开发(一)—安装和部署
git·python·大模型·langflow
怣疯knight3 小时前
【无标题】
git
Jim-zf4 小时前
git 锁文件
git
lcx_defender4 小时前
Git常见操作与指令
git
一只积极向上的小咸鱼15 小时前
嵌套 Git 仓库 / gitlink / submodule 问题总结
大数据·git·elasticsearch
LuDvei16 小时前
git拉取报错问题
git
程序猿多布17 小时前
Fork操作笔记
git·fork