1.目录和文件
显示当前目录路径:
创建/打开目录:
//创建目录
mkdir IOS
//打开目录
open IOS
2.Git库
git配置:
git config --global user.name "Your Name"
git config --global user.email "email@example.com"
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
进入Git远程服务器
初始化远程git仓库:
sudo git init --bare sample.git
git仓库赋权:
sudo chown -R git:git sample.git
把目录变成git仓库:
添加文件到仓库:
把修改提交到仓库。-m后面输入的是提交的说明,可以输入任意内容:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }</style>
查看仓库当前的状态:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
查看文件修改的内容(一般用 git status指令查看到修改的文件,然后用git diff指令查看文件具体的修改内容):
git diff UIViewController+GofHookForGA.m
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px "Hiragino Sans GB" }</style>
显示从最近到最远的提交日志:
同上,不同的是仅显示日志摘要信息:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }</style>
回退到上一个版本:
//HEAD表示当前版本;上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100
git reset --hard HEAD^
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px Helvetica; color: #000000 }
span.s1 { font: 10.0px "PingFang TC" }
span.s2 { }</style>
回退到指定commit id的版本:
//那串数字是commit id。
//版本号没必要写全,前几位就可以了,Git会自动去找。当然也不能只写前一两位,因为Git可能会找到多个版本号,就无法确定是哪一个了
git reset --hard 3628164
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }</style>
记录每一次命令:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
把readme.txt文件在工作区的修改全部撤销:
git checkout -- readme.txt
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }</style>
把暂存区的修改回退到工作区:
git reset HEAD readme.txt
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }</style>
直接删除文件:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
从版本库中删除文件,需要git commit:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "Hiragino Sans GB"; color: #000000 }
span.s1 { font: 10.0px "PingFang TC" }
span.s2 { }
span.s3 { font: 10.0px Helvetica }</style>
本地库和远程库相关联,远程库名称为origin:
git remote add origin https://github.com/GofLee001/swiftdemo.git
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }
span.s3 { font: 10.0px "Hiragino Sans GB" }</style>
把本地库master的所有内容推送到远程库:
//加上-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
git push -u origin master
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
把本地master分支的最新修改推送至GitHub:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }</style>
克隆仓库到本地:
//1.要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆。
//2.Git支持多种协议,包括https,但通过ssh支持的原生git协议速度最快。
git clone git@github.com:GofLee001/swiftdemo.git
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
创建dev分支,然后切换到dev分支:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
创建dev分支:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
切换到dev分支:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
列出所有分支,当前分支前面会标一个*号:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
合并指定分支dev到当前分支:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
删除dev分支:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }</style>
查看分支的合并情况:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
把当前工作现场“储藏”起来,等以后恢复现场后继续工作:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }</style>
查看保存的工作现场:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
恢复工作现场并删除stash:
git stash pop
//上面指令等效于下面这两条指令
git stash apply //恢复工作现场
git stash drop //删除stash
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
强行删除没有合并过的分支dev:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "Hiragino Sans GB"; color: #000000 }
span.s1 { font: 10.0px "PingFang TC" }
span.s2 { }</style>
查看远程库的信息:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "Hiragino Sans GB"; color: #000000 }
span.s1 { font: 10.0px "PingFang TC" }
span.s2 { }</style>
查看远程库的详细信息:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px "Hiragino Sans GB" }</style>
推送自己的修改到远程:
git push origin branch-name
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "Hiragino Sans GB"; color: #000000 }
span.s1 { font: 10.0px "PingFang TC" }
span.s2 { }</style>
在本地创建和远程分支对应的分支:
git checkout -b branch-name origin/branch-name
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px "Hiragino Sans GB" }</style>
建立本地分支和远程分支的关联:
git branch --set-upstream branch-name origin/branch-name
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "Hiragino Sans GB"; color: #000000 }
span.s1 { font: 10.0px "PingFang TC" }
span.s2 { }</style>
从远程拉取分支:
tag相关操作:
//查看所有标签
git tag
//打一个新标签
git tag v1.0
//给指定的commit打标签
git tag v0.9 6224937
//创建带有说明的标签,用-a指定标签名,-m指定说明文字
git tag -a v0.1 -m "version 0.1 released" 3628164
//推送tag到远程
git push origin v1.0
//推送所有本地标签到远程
git push origin --tags
//删除本地标签
git tag -d v0.1
//删除远程的标签
git push origin :refs/tags/v0.1
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
让Git显示颜色:
git config --global color.ui true
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px Helvetica; color: #000000 }
span.s1 { font: 10.0px "PingFang TC" }
span.s2 { }</style>
更新 submodule:
git submodule update --remote
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
设置别名,这里status的别名是st:
git config --global alias.st status
删除submodule:
git submodule deinit 私有库名称
git rm 私有库名称
git rm --cached 私有库名称
rm -rf .git/modules/私有库名称
3.操作Podfile文件
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px Helvetica; color: #000000 }
span.s1 { font: 10.0px "PingFang TC" }
span.s2 { }</style>
创建Podfile文件:
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px Helvetica; color: #000000 }
span.s1 { font: 10.0px "PingFang TC" }
span.s2 { }</style>
用Xcode打开Podfile文件:
4.提交podspec文件:
//1.提交到Github
pod lib lint //pod验证
pod trunk push GofShakeAndEmail.podspec //上传podspec文件到trunk服务器
//2.提交到私有服务器
pod repo push GofSpecs GofNetComponent.podspec
5.其他指令
修改hosts文件:
删除指令:
x 删除光标下的字符 ("dl" 的缩写)
X 删除光标前的字符 ("dh" 的缩写)
D 从当前位置删除到行尾 ("d$" 的缩写)
dw 从当前位置删除到下一个单词开头
db 从当前位置删除到前一个单词的开头
diw 删除光标上的单词 (不包括空白字符)
daw 删除光标上的单词 (包括空白字符)
dG 删除到文件末
dgg 删除到文件首
"dl" 删除字符 (缩写: "x") |dl|
"diw" 删除内含单词 *diw*
"daw" 删除一个单词 *daw*
"diW" 删除内含字串 (见 |WORD|) *diW*
"daW" 删除一个字串 (见 |WORD|) *daW*
"dd" 删除一行 |dd|
"dis" 删除内含句子 *dis*
"das" 删除一个句子 *das*
"dib" 删除内含 ‘(‘ ‘)‘ 块 *dib*
"dab" 删除一个 ‘(‘ ‘)‘ 块 *dab*
"dip" 删除内含段落 *dip*
"dap" 删除一个段落 *dap*
"diB" 删除内含 ‘{ ‘ ‘ }‘ 大块 *diB*
"daB" 删除一个 ‘{ ‘ ‘ }‘ 大块 *daB
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #000000; background-color: #ffffff }
span.s1 { }</style>
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }
span.s2 { font: 10.0px Helvetica }</style>
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 }
span.s1 { }</style>常用Git指令