一:远程创建一个代码共享仓库(GitHub或GitLab)
1.在桌面新建一个文件夹
cd 文件夹路径
2.克隆
git clone 共享版本库地址(gitURL)
二:本地代码仓库
1.初始化一个代码仓库
git init
2.如果使用GIT,必须给GIT配置用户名和邮箱:(当前git仓库配置过了,就用当前的,当前git仓库没有就用全局的) (shift + command + . 显示 .git 隐藏文件,.git --> config 查看, 全局的在 前往 -- > 个人 -- > .gitconfig 查看)
1>. 给当前的git仓库配置用户名和邮箱
git config user.name “用户名”
git config user.email “邮箱”
2>. 给git配置全局的用户和邮箱
git config --global user.name “用户名”
git config --global user.email “邮箱”
3. 提交到本地仓库
git add main.m : 将main.m添加到暂缓区
git add . : 将在⼯工作区所有不在暂缓区的所有内容添加到暂缓区
git commit -m "描述......." : 将在暂缓区的所有内容提交到本地版本库, 清空暂缓区
注意: 添加的文件或者是修改的文件都要通过add命令将该文件添加到暂缓区
4.查看文件状态
git status
(红⾊ : 该文件被添加或者被修改,但是没有添加到git的暂缓区
绿⾊ : 该文件在暂缓区,但是没有提交到本地版本库)
5.从远程仓库拉取代码
git pull
6.提交代码到远程共享版本库
git remote add origin 远程私有库地址 :关联仓库(初始化本地仓库后,首次提交要先关联仓库,再 push ,如果push不成功,根据提示,一般是提示 :git push --set-upstream origin 远程分支名 )
git push :提交代码,正常情况下,经常使用
git push origin 远程分支名 :将本地代码 push 到远程
git push --set-upstream origin 远程分支名 (首次提交的时候会用到这个命令,意思是本地代码仓库关联远程共享仓库分支,简单点来说就是提交到哪个分支,默认创建代码仓库会自动创建一条分支, 下面 分支会详细讲到)
7.给命令行起别名
git config alias.st "status"
git config alias.ci "commit -m"
git config --global alias.st "status"
8.删除文件
git rm person.m : 将person.m删除
9.查看版本信息
git log - > 版本号是由sha1算法生成的40位哈希值
git reflog : 可以查看所有版本回退的操作
10.版本回退
git reset --hard HEAD : 回到当前版本
git reset --hard HEAD^ : 回到上一个版本
git reset --hard HEAD^^ : 回到上上个版本
git reset --hard HEAD~100 :回到前100个版本
git reset --hard 版本号(前5位)
9.给log起别名
git config --global alias.lg "log --color --graph -- pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
三.共享版本库
git服务器的搭建非常繁琐(linux)
可以把代码托管到(Github/OSChina)
一个文件夹
一个U盘
1.一个文件夹作为共享版本库
git init --bare
2.将共享版本库的所有内容下载到本地
git clone 共享版本库地址(文件夹路径)
3.删除忽略文件
touch .gitignore —> Github ->搜索”.gitignore” -> 选择*最多的->找到 Object-C,复制下来
4.版本回退
git reset --hard HEAD^ :回到上一个版本(张三)
git push -f :强制上传到共享版本库
git reset --hard HEAD^ :回到上一个版本(经理)
四:版本备份
1.1.0版本开发完毕,将1.0版本上传到AppStore,对1.0版本进行备份(打上标签)
git tag -a 标签名(例:weibo1.0) -m "这是1.0版本"
git tag :查看当前tag版本
2.需要将标签push到共享版本库
git push origin weibo1.0
3.删除tag
git tag -d v1.1(tag名):删除本地tag
删除远程tag:
git push origin v1.1 (tag名) 或者
git push origin --delete tag V1.1(tag名)
git push origin :refs/tags/V1.1(tag名)
五:分支
查看、创建、切换分支
git branch :查看本地版本库当前在哪个分支
git branch -r :查看共享版本库的分支
git branch -a :查看所有的分支,本地+共享版本库
git checkout 分支名 :切换分支
git branch 分支名 :创建分支
git checkout -b 分支名 :创建分支,并切换到该分支
git push origin 分支名 :将本地创建的分支推送到远程(简单点说就是,你本地创建的,远程没有,你要push到远程)
合并分支:
git checkout master(当前 或者说 主分支) :先切换到 master(当前 或者说 主分支) 分支
git merge 需要合并的分支名 :把需要合并的分支 合并 到 master 分支
git push :合并完记得push
删除分支:
git branch -d 本地分支名 : 删除本地分支
git branch -r -d origin/远程分支名 : 删除远程分支
git push origin --delete 远程分支名:将删除分支push到远程仓库
今天先到这哈,下次有时间再来补充 ~合并分支~ 等命令 和 ~创建远程仓库详细教程xcode git操作,有图有真相那种~,目前需要的可以稍微百度下,很多、很简单的。