
回复
在学校,或许凭借一个人的力量就能负责整个项目的开发到上线。但是在在公司,因为项目的复杂性和紧急性,一个项目的往往是由多个人实现,此时就有一个问题,代码提交和代码合并。git和svn,这篇文章来讲讲git的原理和使用
# git config --global user.name "hello lwl"
# git config --global user.email lwl@csc.com
// 查看系统config
# git config --system --list
// 查看当前用户(global)配置
# git config --global --list
// 查看当前仓库配置信息
# git config --local --list
// 在当前目录新建一个Git代码库
# git init
// 克隆一个项目和它的整个代码历史(版本信息)
# git clone [git@github.com:cscsss/learnHome.git]
git reset branchName fileName
取消暂存。文件状态恢复为 Modified
// 查看所有文件状态
# git status
// 查看指定文件状态
# git status [fileName]
// 添加指定文件到暂存区
# git add [file1] [file2] ...
// 添加指定目录到暂存区,包括子目录文件
# git add [dir]
// 将文件从暂存区和工作区中删除
# git rm <fileName>
// 将 fileName 从暂存区删除文件,仍保留在当前工作目录中
# git rm --cached <fileName>
// 将暂存区文件提交到本地仓库区,message为说明信息
# git commit -m [message]
// 将暂存区的指定文件 fileName 提交到本地仓库
# git commit [fileName] -m [message]
// 追加漏提交的暂存区文件。等价 git add . + git commit -m 'message'
# git commit --amend -m [message]
# git log //查看提交历史
# git log --oneline //以精简模式显示查看提交历史
# git log -p <fileName> //查看指定文件的提交历史
# git blame <fileName> //以列表方式查看指定文件的提交历史
// 显示暂存区和工作区的全部差异
# git diff
// 显示 filepath 路径文件中,工作区与暂存区的差异
# git diff filePath
// 显示在工作区 filePath 文件与 HEAD 分支的差异
# git diff HEAD filePath
// 显示在工作区的 filePath 文件与某次提交 commitId 的差异
# git diff commitId filePath
// git reset [--soft | --mixed | --hard] [HEAD]
// git reset [--soft | --mixed | --hard] [commit]
# git reset –hard HEAD~3 //会将最新的3次提交全部重置,就像没有提交过一样
# git reset 003444c77bae2b0874be17b81a829cfb1237d9ce //重置到003444c7
# git revert -n commitId
// 基于当前分支新建一个分支,并且切换到新的分支 lwl
# git checkout -b lwl
// 基于远程分支 originBranch 并新建分支 csc
# git checkout -b csc originBranch
// 新建一个 csc 分支,但是仍停留在原来分支
# git branch csc
// 切换到 csc 分支
# git checkout csc
~~ 将本地分支的更新全部推送到远程仓库 master 分支
# git push origin master
~~ 删除远程 branchname 分支
# git push origin -d <branchName>
# git branch -D <branchname>
~~ 删除本地 dev1 分支
# git branch -D dev1
# git merge branchName //当前分支和 branchName 合并
# git merge -m <msg> <commit> //当前分支和 branchName commit及之前的提交合并
# git merge --abort // 取消合并
<<<<<<<
,=======
和>>>>>>>
表示。在=======
之前的部分是当前分支这边的情况,在=======
之后的部分是对方分支的情况git add
加入到index中,然后使用git commit
产生合并节点
~~ 拉取所有远端的最新代码
# git fetch --all
~~ 拉取远程最新 master 分支代码(指定 master 分支)
# git fetch origin master
~~ 拉取远程仓库分支,更新并合并到本地分支
# git pull
~~ 将远程 master 分支合并到当前本地 master 分支
# git pull origin master
~~ 将远程 master 分支合并到当前本地 lwl 分支,冒号后面表示本地分支
# git pull origin master:lwl
git rebase --continue
# git rebase branchName // branchName 合并到当前分支
# git rebase --continue // 解决冲突后继续合并
# git rebase --abort //取消合并
# git rebase -i HEAD~2 //合并提交 --- 2表示合并2个。也可以是3...
# git tag <tagName> //基于最新的 commitId 创建 tagName
# git tag -a <tagName> <commitId> // 基于某次 commitId 创建 tagName
# git push origin <tagName> //推送到远程仓库
# git push --tags //推送所有标签
# git tag -d <tagName> // 删除本地 tag
# git push origin :refs/tags/<tagName> // 删除远程 tag
[1]一个小时学会Git:https://www.cnblogs.com/best/p/7474442.html
[2]程序员必备基础:Git 命令全方位学习:https://www.cnblogs.com/jay-huaxiao/p/13198979.html
[3]Git Reset 三种模式:https://www.jianshu.com/p/c2ec5f06cf1a
文章转载自公众号:潜行前行