一、概念
一个免费开源、分布式的代码版本控制系统,帮助开发团队维护代码
二、作用
记录代码内容,切换代码版本,多人开发时高效合并代码内容
三、配置用户信息
应用于每次提交代码版本时表明自己的身份
git config --global user.name "用户名” |
git config --global user.email "邮箱” |
四、git的三个区域
工作区 | 实际开发时操作的文件夹 |
暂存区 | 保存之前的准备区域(暂存改动过后的文件) |
版本库 | 提交并保存暂存区的内容,产生一个版本快照 |
五、文件状态
未跟踪 U | 从未被Git管理---属于新文件 |
已跟踪 A | 第一次被Git暂存的---之前版本记录无此文件 |
未修改 '' | 三个区域统一---提交保存后 |
已修改 M | 工作区内容变化---修改了内容产生的 |
六、常用的命令
git add 文件名 | 暂存指定文件,文件名最好是绝对路径 |
git add . | 暂存所有改动过的文件 |
git commit -m '注释说明' | 提交并保存暂存区的内容到版本库 |
git ls-files | 查看暂存区有哪些文件 |
git log --oneline | 查看提交的历史记录 |
git reflog --oneline | 查看完整日志(若是记录过长,enter键可以查看未显示完整的记录,Q键结束进程) |
git status | 查看文件状态的详细信息 |
git status -s | 查看文件状态的简略信息(第一列是暂存区状态,第二列是工作区状态) |
git restore 目标文件 | 覆盖目标文件(完全确认覆盖时使用,暂存区--->覆盖--->工作区) |
git rm --cached 目标文件 | 从暂存区移除文件 |
git reset --soft 版本号 | 其他文件回退到未跟踪的状态(保留) |
git reset --hard 版本号 | 会清理其他文件(覆盖) |
git reset --mixed 版本号 | 暂存区被覆盖,工作区内容仍然保留(类似于soft) |
git branch | 查看当前git库有哪些分支 |
git branch 分支名 | 创建新分支 |
git checkout 分支名 | 切换分支 |
git checkout -b 分支名 | 创建并立刻切换分支 |
git merge 分支名 | 合并分支 |
git checkout -d 分支名 | 删除分支 |
git remote add 远程仓库别名 远程仓库地址 | 本地git仓库中添加远程仓库地址 |
git remote remove 远程仓库别名 | 删除远程仓库 |
git remote -v | 查看远程仓库的地址 |
git pull 远程仓库别名 分支名 | 拉取远程仓库的内容 |
git push 远程仓库别名 分支名 | 推送到远程仓库 |
git push -u 远程仓库别名 分支名 | 推送的完整写法 |
git pull --rebase 远程仓库别名 分支名 | 拉取并合并 |
git clone 远程仓库的地址 | 克隆 |
cd 文件夹 | 进入某文件夹中 |