标签:
一、简介
在Mac上,比较好用的git图形界面客户端有
1 01. GIT简介(PPT) 2 ================================================================================ 3 4 02. GIT命令行帮助 5 ================================================================================ 6 $ svn help 7 查看svn所有命令的帮助 8 $ svn help 子命令 9 10 # 要退出帮助信息,按"q" 11 # 翻看下页,按"空格" 12 # 翻看上页,按"CTRL+B" 13 # 要搜索相关文字,按"/"然后输入"相关文字" 14 15 03. 创建代码库 & 配置个人信息 16 ================================================================================ 17 1> 创建代码仓库 18 $ git init 19 20 2> 配置用户名和邮箱 21 $ git config user.name lnj 22 $ git config user.email lnj@gmail.com 23 24 * 以上两个命令会将用户信息保存在当前代码仓库中 25 26 # 只有配置了用户和邮箱之后,git才能识别出操作的人员信息,通过钩子(hooks)程序可以设置一些动作 27 # 例如单元测试发现问题后,自动给相关人员发送电子邮件 28 * 注意 暂时不建议投入一毛钱精力 29 30 3> 如果要一次性配置完成可以使用一下命令 31 $ git config --global user.name lnj 32 $ git config --global user.email lnj321@gmail.com 33 34 * 以上两个命令会将用户信息保存在用户目录下的 .gitconfig 文件中 35 36 4> 查看当前所有配置 37 $ git config -l 38 39 04. 实际开发 40 ================================================================================ 41 1> 创建代码,开始开发 42 $ touch main.c 43 $ open main.c 44 45 2> 将代码添加到代码库 46 # 查看当前代码库状态 47 $ git status 48 # 将文件添加到代码库 49 $ git add main.c 50 # 将修改提交到代码库 51 $ git commit -m "添加了main.c" 52 53 提示: 54 * 在此一定要使用 -m 参数指定修改的备注信息 55 * 否则会进入 vim 编辑器,如果对vim不熟悉,会是很糟糕的事情 56 57 # 将当前文件夹下的所有新建或修改的文件一次性添加到代码库 58 $ git add . 59 60 3> 添加多个文件 61 $ touch Person.h Person.m 62 $ git add . 63 $ git commit -m "添加了Person类" 64 $ open Person.h 65 $ git add . 66 $ git commit -m "增加Person类属性" 67 68 * 注意 使用git时,每一次修改都需要添加再提交,这一点是与svn不一样的 69 70 git 的重要概念及工作原理 71 -------------------------------------------------------------------------------- 72 工作区 73 暂存区(staged) 74 分支(HEAD) 75 76 05. 别名 & 日志 77 ================================================================================ 78 $ git config alias.st status 79 $ git config alias.ci "commit -m" 80 81 个人建议:除非特殊原因,最好不要设置别名,否则换一台机器就不会用了 82 83 # 查看所有版本库日志 84 $ git log 85 # 查看指定文件的版本库日志 86 $ git log 文件名 87 88 # 配置带颜色的log别名 89 $ 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" 90 91 提示:在git中,版本号是一个由SHA1生成的哈希值 92 93 06. 版本号,让我们在任意版本之间穿梭 94 ================================================================================ 95 # 回到当前版本,放弃所有没有提交的修改 96 $ git reset --hard HEAD 97 # 回到上一个版本 98 $ git reset --hard HEAD^ 99 # 回到之前第3个修订版本 100 $ git reset --hard HEAD~(3) 101 # 回到指定版本号的版本 102 $ git reset e695b67 103 104 # 查看分支引用记录 105 $ git reflog 106 107 07. 单个文件的修改管理 108 ================================================================================ 109 # 查看文件变化 110 $ git diff 111 # 撤销对文件做的修改 112 $ git checkout Person.h 113 # 从代码库(暂存区中删除文件)
1 01. 建立代码仓库(专门用于团队开发的代码仓库) 2 ================================================================================ 3 4 # 切换目录 5 $ cd /Users/lnj/Desktop/git演练/公司/weibo 6 # 建立空白代码库(专门用于团队开发) 7 $ git init --bare 8 9 02. 项目经理准备项目(前奏) 10 ================================================================================ 11 12 # 切换目录 13 $ cd /Users/lnj/Desktop/git演练/经理 14 # "克隆"代码库到本地 15 $ git clone /Users/lnj/Desktop/git演练/公司/weibo/ 16 17 # 个人信息配置(因为要演示一台机器上的多人协作,日常开发可以忽略) 18 $ git config user.name manager 19 $ git config user.email manager@163.com 20 21 .gitignore 22 -------------------------------------------------------------------------------- 23 .gitignore可以指定哪些文件不纳入版本库的管理 24 25 参考网址:https://github.com/github/gitignore 26 27 # 命令行中进入与.git同级的目录 28 $ cd /Users/lnj/Desktop/git演练/经理/weibo 29 30 将以下命令一次性粘贴到命令行中 31 -------------------------------------------------------------------------------- 32 echo -e "# Xcode 33 # 34 build/ 35 *.pbxuser 36 *.mode1v3 37 *.mode2v3 38 *.perspectivev3 39 xcuserdata 40 *.xccheckout 41 *.moved-aside 42 DerivedData 43 *.hmap 44 *.ipa 45 *.xcuserstate 46 # CocoaPods 47 # 48 # We recommend against adding the Pods directory to your .gitignore. However 49 # you should judge for yourself, the pros and cons are mentioned at: 50 # http://guides.cocoapods.org/using/using-cocoapods.html#should-i-ignore-the-pods-directory-in-source-control 51 # 52 # Pods/" > .gitignore 53 -------------------------------------------------------------------------------- 54 # 将.gitignore添加到代码库 55 $ git add .gitignore 56 57 03. 创建项目 58 ================================================================================ 59 提交同时"push"到远程代码仓库 60 61 04. 新人加入 62 ================================================================================ 63 64 ... 65 66 05. 分布式的代码库 - 仅供参考 67 ================================================================================ 68 由于git是分布式的,任何一台计算机上都保留有完整的代码库的内容,因此可以把团队开发的代码库放在任何位置 69 70 71 多个远程代码库之间的同步演练"提示,此演练仅供了解,具体的使用,需要一定的团队规模之后,才能够体会" 72 73 74 06. 分支管理 - Tag 75 ================================================================================ 76 # 查看当前标签 77 $ git tag 78 # 在本地代码库给项目打上一个标签 79 $ git tag -a v1.0 -m ‘Version 1.0‘ 80 # 将标签添推送到远程代码库中 81 $ git push origin v1.0 82 83 # 使用tag,就能够将项目快速切换到某一个中间状态,例如产品开发线上的某一个稳定版本 84 # 签出v1.0标签 85 $ git checkout v1.0 86 # 从签出状态创建v1.0bugfix分支 87 $ git checkout -b bugfix1.0 88 89 # 查看远程分支 90 $ git branch -r 91 # 删除远程分支 92 $ git branch -r -d origin/bugfix1.0
1 01. 分布式的代码库 - 仅供参考 2 ================================================================================ 3 由于git是分布式的,任何一台计算机上都保留有完整的代码库的内容,因此可以把团队开发的代码库放在任何位置 4 5 6 多个远程代码库之间的同步演练"提示,此演练仅供了解,具体的使用,需要一定的团队规模之后,才能够体会" 7 8 9 02. 分支管理 - Tag 10 ================================================================================ 11 # 查看当前标签 12 $ git tag 13 # 在本地代码库给项目打上一个标签 14 $ git tag -a v1.0 -m ‘Version 1.0‘ 15 # 将标签添推送到远程代码库中 16 $ git push origin v1.0 17 18 # 使用tag,就能够将项目快速切换到某一个中间状态,例如产品开发线上的某一个稳定版本 19 # 签出v1.0标签 20 $ git checkout v1.0 21 # 从签出状态创建v1.0bugfix分支 22 $ git checkout -b bugfix1.0 23 24 # 查看远程分支 25 $ git branch -r 26 # 删除远程分支 27 $ git branch -r -d origin/bugfix1.0
1 如何使用/学习第三方框架? 2 3 优秀的第三方框架都在 github.com 4 5 1> 搜索 6 2> git clone 获得完整版本 7 $ git clone https://github.com/AFNetworking/AFNetworking.git 8 3> 获取最新版本 git pull 9 * 进入clone的本地文件夹 10 $ git pull 11 12 4> 看github上的文档,优秀的第三方框架都有好的文档 13 5> 编写测试程序,看运行结果 14 6> 针对感兴趣的部分,看源代码 15 16 7> 有问题去http://stackoverflow.com
标签:
原文地址:http://www.cnblogs.com/oc-bowen/p/5263229.html