自己用git的笔记(自看防止忘记)

一般情况下使用的

创建一个本地没有的分支并且拉取该分支的远程分支数据
git checkout -b 分支名字 origin/远程分支的名字
查看日志信息
git log 分支名字
强制回滚某次提交记录那
git reset --hard 提交记录的标示
强制提交
git push -f origin 分支名字
重置暂存区与工作区,与上一次commit保持一致
git reset --hard

经常使用的

获取远程分支信息
git fetch 
查看所有的分支
git branch -a
查看远程分支
git branch -r
查看本地的分支
git branch 
创建一个本地的分支
git checkout -b 分支名字
删除本地的分支
git branch -D 分支名字
删除远程的分支
git push origin -d 分支名字
从当前分支切换到另一个分支
git checkout 分支名字
拉取远程分支的信息
git pull origin 分支名字
克隆远程仓库的信息
git clone 远程分支仓库的链接
常看当前分支的状态
git status 
查看某一个文件的修改变化
git diff 文件的路径
列出所有的tag
git tag
在本地代码库给项目打上一个标签
git tag -a tag名字 -m '描述信息'
新建一个tag在本次的commit
git tag 名字(比如:v1.0.0)
新建一个tag在指定的commit
git tag 名字(比如:v1.0.0) commit的标识
删除本地的tag
git tag -d tag名字
将本地建的tag传到远程
git push origin tag名字
将本地的所有分支的tag提交到远程去(所有的tags)
git push origin --tags
将本地的所有分支的tag提交到远程去(单个tag)
git push origin tag名字
从当前的tag切换到另外一个tag
git checkout tag名字
删除远程的tag
git push origin :refs/tags/ tag名字
删除远程的tag(这个也可以)
git tag origin :tag名字
显示远程的tag
git ls-remote --tags origin
显示一个tag的信息
git show tag名字
将某一个分支合并当前的本地分支
git merge 别的分支名字
git合并两个远程分支
需要将两个分支拉到本地 ,然后在本地合并,解决完冲突在提交

一些其他的命令,并且有的命令没有验证过

mac电脑上显示隐藏文件夹( 验证过)
defaults write com.apple.finder AppleShowAllFiles Yes && killall Finder
mac电脑上隐藏隐藏文件夹( 验证过)
defaults write com.apple.finder AppleShowAllFiles No && killall Finder
删除 untracked files(未验证)
git clean -f
连 untracked 的目录也一起删掉(未验证)
git clean -fd
连 gitignore 的untrack 文件/目录也一起删掉 (慎用,一般这个是用来删掉编译出来的 .o之类的文件用的)(未验证)
git clean -xfd
在用上述 git clean 前,墙裂建议加上 -n 参数来先看看会删掉哪些文件,防止重要文件被误删(未验证)
git clean -nxfd
git clean -nf
git clean -nfd

一些偏门的东西

自己的一个本地库添加到远端
git remote add origin 远程仓库的地址
发现自己的pod 怎么都不好使了 可以尝试进行这样的操作
rm -rf Podfile.lock
rm -rf Pods
pod install
open 你的工程.xcworkspace
如果发现自己发布的库成功了,但是pod search 搜索不到
可以在前往 -》个人 -》资源库 -》Caches -》CocoaPods -》 search_index.json
删除他 然后在重新pod search (他将进行重新安装,前提要能显示隐藏文件夹)
cocoapods 在哪里
可以在前往 -》个人 -》cocoapods(前提要能显示隐藏文件夹)
podspec是一个仓库的描述文件,他的具体说明待整理

远程仓库的关联与取消
连接远程仓库
git remote add origin 仓库地址
查看远程连接
git remote -v
git取消与远程仓库的连接
git remote remove origin
如果gitignore明明文件路径是对的 但是确实不起作用
使用这个命令,然后重新提交gitignore,即可以起作用了。
git rm -r --cached .
如果自己的本地分支没有任何的修改,但是执行rebase之后发生冲突,可以这样解决(没敢验证)
先执行这个命令 
git rebase --onto 目标分支(比如develop) 标识(比如某个节点的提交记录)
然后
git pull --rebase origin 目标分支(比如develop)

原文:https://stackoverflow.com/questions/40524681/why-git-rebase-shows-conflicts-in-the-files-i-did-not-modify

特别说明一下这个命令的含义
pod update --no-repo-update
这条命令表示只根据本地目录更新库,不需要拉取远程
如果发现执行 git pull 之后还是还是提示说自己没有拉取,那么执行这个命令
git pull origin 分支  --allow-unrelated-histories

你可能感兴趣的:(自己用git的笔记(自看防止忘记))