Git

----本地仓库----

1.新建一个“本地仓库”

  • git init

2.配置仓库

①告诉git你是谁

  • git config user.name syl

②告诉git怎么联系你

  • git config user.email syl@qq.com

上面一种配置方式是一次性的配置, 会配置到被管理文件的。git文件夹下

下面一种配置方式是一劳永逸的方式:

  • git config --global user.name syl
  • git config --global user.email syl@qq.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 文件名

    • 如果显示绿色代表新增
    • 如果显示红色代表删除

----远程仓库----

  • 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上显示的昵称而不是登录账号

源代码管理git的使用的更多相关文章

  1. iOS开发——源代码管理——git(分布式版本控制和集中式版本控制对比,git和SVN对比,git常用指令,搭建GitHub远程仓库,搭建oschina远程仓库 )

    一.git简介 什么是git? git是一款开源的分布式版本控制工具 在世界上所有的分布式版本控制工具中,git是最快.最简单.最流行的   git的起源 作者是Linux之父:Linus Bened ...

  2. 源代码管理git地址从http改为https,提交400错误

    推送400错误 cmd 执行 git config --global http.sslVerify false 推送地址,修改http 为 https 就可以正常提交了

  3. 使用git进行源代码管理

    git是一款非常流行的分布式版本控制系统,使用Local Repository追踪代码的修改,通过Push和Pull操作,将代码changes提交到Remote Repository,或从Remote ...

  4. git与svn, tfs等源代码管理器的协同

    简单地说,这三个都是业界知名的源代码管理器.他们是有区别的,根本的区别在于git是分布式源代码管理器(每个本地都有完整的代码,及历史),而svn和tfs是集中式源代码管理器(只有服务器才有完整的历史, ...

  5. Git 源代码管理工具

    Git 源代码管理工具 Git基本信息 Git :Git是一个“分布式”的版本控制工具 Git的作者是Linux之父 Linus Benedict Torvolds,当初开发Git仅仅是为了辅助Lin ...

  6. 基于git的源代码管理模型——git flow

    基于git的源代码管理模型--git flow A successful Git branching model

  7. VS.net 2013中使用Git建立源代码管理 版本管理

    第一次在VS2013中使用Git,也是第一次使用Git,各种不熟悉.百度各种使用经验,大都不屑于使用VS2013集成的Git,建议下载这个下载那个,我也照学了,确实能实现项目的提交.同步.合并的工作, ...

  8. [Tool] 源代码管理之Git

    本节目录 什么是Git 什么是GitHub 安装Git GitHub之Repository GitHub之托管页面 常用Git 命令 什么是Git 由于现在的开发多人协同办公,因此出现源代码管理工具 ...

  9. git@oschina.net源代码管理使用日记

    git的优势: 1 可以创建分支: 2 版本控制是基于每一次提交的,而不需要考虑每次提交了多少个文件. 下载: 下载网址为:http://git-scm.com/download,根据您的操作系统选择 ...

随机推荐

  1. hdoj-2090-算菜价(水题)

    算菜价 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submis ...

  2. nhibernate的关系

    用nhibernate,觉得比较难把握的是其中表间的关系. 我用的是Fluently Nhibernate,直接用代码,而不是XML来书写代码与数据表的映射.其中表间关系有3种: 1.Referenc ...

  3. POI异步导入Excel兼容xsl和xlsx

    项目架构:spring+struts2+hibernate4+oracle 需求:用户导入excel文件,导入到相应的数据表中,要求提供导入模板,支持xls和xlsx文件 思路分析: 1.提供一个下载 ...

  4. UVA 437 The Tower of Babylon巴比伦塔

    题意:有n(n≤30)种立方体,每种有无穷多个.要求选一些立方体摞成一根尽量高的柱子(可以自行选择哪一条边作为高),使得每个立方体的底面长宽分别严格小于它下方立方体的底面长宽. 评测地址:http:/ ...

  5. ABAP 检查全角半角

    check全角or半角的方法 第一种方法SJIS_DBC_TO_SBC 全角转半角 SJIS_SBC_TO_DBC 半角转换为全角 设定 import all =xtext = 文本全角-〉半角,返回 ...

  6. (1)iOS9完美越狱

    方式一:同步推越狱,其实用的也是方式二 参考:iOS9.3.5不完美越狱(点击跳转) 方式二:使用impactor越狱. 下载地址:http://www.pc6.com/mac/505285.html

  7. Java语法基础练习2

    ---恢复内容开始--- 1.仔细阅读示例:EnumTest.java分析结果 代码: 运行结果: 分析:枚举类型就是一个类,枚举中的常量就是枚举类型中的实例,可把字符串转化为枚举:而且他本身是一个类 ...

  8. ChartCtrl源码剖析之——CChartAxis类

    CChartAxis类用来绘制波形控件的坐标轴,这个源码相对较复杂,当初阅读的时候耗费了不少精力来理解源码中的一些实现细节. CChartAxis类的头文件. #if !defined(AFX_CHA ...

  9. 洛谷 P2593 [ZJOI2006]超级麻将【dp】

    设f[i][j][k][0/1]表示选到i时,i-1选j张,i选k张,之前选的所有牌是否选择了对子 然后分情况讨论转移即可 #include<iostream> #include<c ...

  10. bzoj 1112: [POI2008]砖块Klo【对顶堆】

    priority_queue实现的对顶堆,细节超级多WA了十几次--但是理论上是最简便的orz其实是我已经不会写平衡树了 枚举左端点,显然要把这一段的高度搞成(l,l+k-1)的高度中位数,所以需要一 ...