git 学习笔记
注册个人信息
- git config --global user.name(你的用户名)
- git config --global user.email(你的邮箱)
- 然后到github官网注册个人账号
- 在github创建仓库
- 创建本地仓库,可以选取一个目录作为仓库,目录的路径名称最好不要带有中文字符
- 创建SSH Key ssh-keygen -t rsa -C "youremail@example.com"
检出项目到本地
- cd Repository(本地仓库) -- 切到本地仓库
- git init 初始化本地仓库
- git -help 获取提示信息
- 输入命令行:git clone url ,其中url对应的是你的github上仓库的SSH或者是HTTP链接
提交项目
- git status 查看当前工作状态
- git add fileName 提交项目到本地暂存区
- git commit -m 提交变更到head中,填写变更评论,目的是在将来查看项目时知道变更的原因,准确定位到 何时何地何原因 修改目的
- git push url 推送到远程仓库
- 输入用户名和密码,接下来会看到提示推送成功
- 再一次执行 git status 查看工作区状态
删除文件及一键恢复
- git rm fileName (删除文件)
- git commit (确认删除)
- git checkout -- test.txt
- git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
代码冲突问题及查看变更内容
- git diff 比较的是工作区文件与暂存区文件的区别(上次git add 的内容)
- git diff --cached 比较的是暂存区的文件与仓库分支里
- git pull 合并冲突,会保留两次修改
回到过去/将来
主要将项目恢复到过去的状态
- git log (-- pretty=online)查看提交记录
- 获取提交记录的commit的id
- 执行 git reset --hard id
- hard是指向当前版本的指针
主要将项目恢复到将来的状态
- git reflog 可以看到当前列出最新的版本号的一个状态,拿到commit的id
- 执行 git reset --hard id
建立里程碑
分支开发之分支合并
- 在github上创建一个分支
- 添加分支的名称
- merge 合并
多人合作经验
- 多用客户端和工具,少用命令行,除非是在linux服务器上直接开发
- 每次提交前,diff自己的代码,以免提交错误的代码
- 下班回家前,整理好自己的工作区
- 并行的项目,使用分支开发,提高工作效率
- 遇到冲突时,搞明白冲突的原因,千万不要随意丢弃别人的代码
- 产品发布后,记得打tag,方便将来拉分支修bug