一、Git
----本地仓库----
1.新建一个“本地仓库”
- git init
2.配置仓库
①告诉git你是谁
- git config user.name lnj
②告诉git怎么联系你
- git config user.email lnj@itcast.cn
上面一种配置方式是一次性的配置, 会配置到被管理文件的。git文件夹下
下面一种配置方式是一劳永逸的方式:
- git config --global user.name syl
- git config --global user.email sylqq.com
3、如何学习git指令
<1>、git常规指令
- git status 查看文件状态
- git add . 添加文件到“暂存区”
- git commit -m "注释" 文件名称 添加文件到”本地仓库“
注意:
<2>、如果没有在commit后面加上 -m说明修改了什么, 会自动进入vim界面, 要求我们输入修改信息
- 按键盘上的 i 代表开始输入内容
- 输入完毕之后按 esc 然后按 :wq
所以: 如果以后在终端中提交最好在后面加上-m
<3>、注意:
- git中的add和SVN中的add不太一样, SVN中只需要add一次, 而git中每次新建或者修改之后都需要重新add
①红色 代表在”工作区“
- 为添加之前的颜色
②绿色 代码在”暂存区“
- 添加到暂存区之后的颜色
<4>、注意:
git默认没有简写指令
注意:
一般情况下不建议自定义简写指令
- git中的简写称之为起别名
别名 & 日志
- $ git config alias.st status
- $ git config alias.ci "commit -m"
<5>、查看log
- git log 文件名
-
注意:
GIt中的版本号是一个”40位“的哈希值, - 而SVN中的版本号是一个递增的整数
配置带颜色的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 reset —hard HEAD^ 返回上一个版本
- 其中—hard代表强制重置
git reset —hard 版本号(只需要写前7位)
②未提交
- git checkout 文件名 回退到上一次提交的版本
- git reset —hard HEAD 回退到上一次提交的版,
注意HEAD后面没有尖号^
c9ad690 HEAD@{0}: commit: main.c
7026f99 HEAD@{1}: commit: 输出结果
e950c89 HEAD@{2}: commit: 新增输入
c7bf91c HEAD@{3}: commit: 添加变量
cbd9e52 HEAD@{4}: commit: 删除print函数
45ea44d HEAD@{5}: commit: 添加了printf函数
0da06d8 HEAD@{6}: commit (initial): i
<6>、git reflog 查看所有修改信息(所有版本)
<7>、查看文件被修改的什么地方
- git diff 文件名
- 如果显示绿色代表新增
- 如果显示红色代表删除
image.png
----远程仓库----
- SVN需要一个单独的服务器
- Git不需要: 文件中、U盘中、云上、github、OSChina...
1.新建git远程仓库
- git init —bare
-
注意:
这个仓库仅仅是用于管理代码, 不参与开发
2.项目经理初始化项目
2.1先克隆一份空得仓库到本地
- git clone /Users/apple/Desktop/working/公司远程仓库
2.2忽略不需要加入版本控制器的文件以及文件夹
- .gitignore
-
注意:
配置忽略文件只需要到github上搜索.gitignore拷贝别人写好的代码即可 - 配置.gitignore一定要在和.git隐藏文件夹同一级的目录下
2.3生成好.gitignore文件之后, 还需要将.gitignore文件添加到版本控制
- git add .gitignore
- git commit .gitignore -m””
2.4新建项目
source conrol—>commit 将代码提交到本地仓库
source conrol—>push 将代码提交到远程仓库
git中默认就会创建一个分支, 这个分支叫做origin/master, 相当于svn中的trunk
专业人员只需要在git仓库的hooks文件夹中写一些指令, 就可以完成自动测试(压力测试、自动测试、集成测试、冒烟测试、。。。)
和SVN一样, 如果服务器仓库的代码被修改了, 我们再提交代码也会报错。
fetch first == out of data
总结:
git和svn最大的区别
- 1.git每次修改新增都需要add
- 2.git每台电脑都有一个仓库
- 3.git是先提交到本地仓库, 再提交到远程仓库
----gitHub----
通过Xcode将代码提交到github上, 把仓库放在github上
1.注册一个github账号
2.配置SSH Keys, 只要配置了SSH
Keys就可以和github无缝衔接
- 点击昵称来到个人主页
- 点击主页中的设置(setting)
- 点击SSH Keys
- 点击 generating SSH keys
1.检查本地的ssh keys
- 在“用户目录”下 ls -al ~/.ssh
2.如果文件夹不存在需要手动创建一个
- mkdir .ssh
3.根据github的提示2生成ssh keys
- 在.ssh目录下执行
- ssh-keygen -t rsa -C "your_email@example.com”
输入完成之后连续按下回车, 知道出现牛逼的图形位置
4.生成完公钥和私钥之后输入
- ls -la查看是否生成成功
- id_rsa(私钥) id_rsa.pub(公钥)
5.根据提示3获得公钥
- pbcopy < ~/.ssh/id_rsa.pub
6.点击 setting —》 ssh key —>add ssh key
- 将刚才获取到得公钥添加进去
7.根据github第4步提示, 验证公钥
- 验证成功网页上的灰色圆点会变成绿色
8.拷贝到公钥之后打开github主页
- 点击仓库(Repositories)
- 再点击new来到github创建仓库界面
9.通过github提供的地址下载一个空得仓库到本地
- 创建一个新的项目到本地仓库文件夹中
- 利用Xcode提交代码到github
- 注意: 要求输入用户名密码时候, 输入的是github上显示的昵称而不是登录账号
image.png
二、SVN
- 全称是Subversion,集中式版本控制之王者
- SVN 版本控制,需要自己搭建一个管理代码的服务器,提供开发人员,上传和下载
1.基本介绍
image.png
使用环境
要想利用SVN管理源代码,必须得有2套环境
服务器
- 用于存储客户端上传的源代码
- 可以在Windows上安装Visual SVN Server
- 大部分情况下,公司的开发人员不必亲自搭建SVN服务器
客户端
- 上传本地的源代码到服务器,或者更新服务器的代码到本地,保持同步
- 可以在Mac上使用命令行、Versions、Cornerstone、Xcode
- 开发人员就属于客户端这个角色
2.搭建服务器
Visual SVN Server下载地址
服务器安装(windows安装)
image.png
image.png
image.png
image.png
image.png
image.png
image.png
image.png
服务器创建代码仓库
image.png
image.png
image.png
image.png
image.png
image.png
image.png
image.png
3.基本操作(命令行)
- 先进入创建的存放项目文件夹目录
项目经理初始化项目
①.将服务器所有的内容下载到本地
- svn checkout 服务器地址 —username=mgr —password=mgr
②.进⼊入到工作目录
- cd 工作目录
③.初始化项⺫
- touch main.m 添加文件和项目
④.将main.m加⼊入到本地代码管理中
- svn add main.m
⑤.将main.m提交到服务器
- svn commit -m “注释”
⑥.查看⽂文件的状态(svn status—>简写svn st)
- svn st 显示的文件状态
文件状态
- ' ' 没有修改
- 'A' 被添加到本地代码仓库
- 'C' 冲突
- 'D' 被删除
- 'I' 被忽略
- 'M' 被修改
- 'R' 被替换
- 'X' 外部定义创建的版本目录
- '?' 文件没有被添加到本地版本库内
- '!' 文件丢失或者不完整(不是通过svn命令删除的文件)
- '~' 受控文件被其他文件阻隔
⑦.删除
删除服务器上的某个文件,需要做2个步骤
- 将文件从本地的版本控制库中移除:svn delete 、svn remove
- 提交刚才的删除操作到服务器:svn commit
将文件从本地的版本控制库中移除
- svn delete 文件名
⑧.查看日志
查看日志,需要2个步骤
- 将服务器的最新代码更新到本地:svn update
- 查看日志:svn log
⑨.添加
提交一个新建的文件到服务器,需要2个步骤
- 添加新建的文件到本地的版本控制库中:svn add
- 提交刚才的添加操作到服务器:svn commit
如果直接提交一个没有添加到本地版本控制库中的文件,会报下面的错误
- is not a working copy
⑩.更新
将服务器的最新代码更新到本地
- svn update [PATH]
将文件恢复至某个版本
- svn update -r 版本号 [PATH]
⑪.代码冲突问题:
a.无法提交代码提示错误:out of date
- 过期—>如果本地的版本号⼩小于服务器的版本号是 不能提交
- 先更新一下,在查看冲突 conflict discovered
b.代码冲突的解决⽅方案:
- (p) postpone : 对⽐比所有的版本的代码,⼿手动解决冲突
- (mc) mine-conflict : 使⽤用我的代码覆盖服务器的代码
- (tc) theirs-conflict : 使⽤用服务器代码覆盖我的代码
- (df) diff-full : 展⽰示全部的不同.是在命令⾏行中展⽰示
- (e) edit : 直接编译⽂文件,但是也是在命令⾏行中编辑
- (s) show all options: 再次展⽰示所有的选项
c.选择postpone查看⽂文件中的代码
- 在冲突的文件中有冲突展示
<<<<<<< .mine
我的代码
=======
服务器的代码
>>>>>>> .r16
- 在代码中修改后保存文件
- 再删除多余的文件
d.解决冲突之后命名:svn resolved ⽂文件名
4.总结
-
去到公司的第一天,下载公司的代码到电脑上
- svn checkout
-
修改了某个早已存在的旧文件,然后提交到服务器
- svn commit
-
提交一个自己新建的文件到服务器
- svn add -> svn commit
-
删除一个早已存在的旧文件,然后同步到服务器上
- svn delete -> svn commit
-
将其他同事提交的新代码更新到自己电脑上
- svn update
-
不小心写错了很多东西,想撤销所写的东西(还未把修改提交到服务器)
- svn revert
-
不小心删错了文件,想把文件恢复回来(还未把删除提交到服务器)
- svn revert
-
不小心写错了很多东西,想撤销所写的东西(已经把修改提交到服务器)
- svn update -r 版本号
-
不小心删错了文件,想把文件恢复回来(已经把删除提交到服务器)
- svn update -r 版本号
image.png
5.图形化工具的使用(Xcode 和 Cornerstone/Versions)
-
一张图概括
image.png
- Xcode工具不能忽略一些不需要的文件,可以使用命令行或者Cornerstone