Git的简单使用

一.什么是Git

git 是一款开源的分布式版本管理工具,最初由Linus Torvalds创作,于2005年以GPL发布,最初目的是为了更好的管理Linux内核开发而设计.

git 最初的开发动力是来自于BitKeeper和Monotone,git最初只是作为一个可以被其他前端包装的后端而开发的,但后来git内核已经成熟到可以独立地用作版本控制,很多著名的软件都使用git进行版本控制.

现在世界上所有的分布式版本控制工具中,git是最快、最简单、最流行的

版本控制:集中式、分布式

集中式:集中式版本控制系统,版本库是集中存放在中央服务器的,而工作的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。中央服务器就好比是一个图书管,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回到图书馆。
缺点:必须得联网时才能工作,自己电脑上没有服务器,只能请求网上的服务器获得资源。(SVN)

分布式:分布式版本控制系统没有中央服务器,每一个电脑上都是一个完整的版本库,工作的时候都不需要联网当两个或者两个以上的人分别修改了不同的文件的时候,只需要把各自修改的内容推送给对方即可,可以互相看到对方的修改了。安全性高,只要有一台电脑没有坏,就能重新得到完整的版本库,不会跟集中式的一样,中央服务器炸了就什么都没有了。

git是一款开源的分布式版本控制工具,在世界上所有的分布式版本控制工具中,git是最快、最简单、最流行的

作者是Linux之父: Linus Benedict Torvalds
当初开发git仅仅是为了辅助Linux内核的发开(管理源代码)

国外非常普及,国内一般
越来越多的开源项目已经转移到git

显示隐藏文件(Mac OS)

$ defaults write com.apple.finder AppleShowAllFiles -bool true
  • 需要重启Finder

</br>

二. 个人开发(命令行)

1.进入到工作目录中(就是你想要将git仓库创建的位置),初始化一个代码仓库

$ git init

2.给这个git仓库配置一个用户名和邮箱

$ git config user.name "username"
$ git config user.email "useremail@gmail.com"

3.初始化代码

$ touch main.m
$ git add main.m

4.查看文件状态

$ git status
  • 文件显示为红色:新添加的文件或者修改的文件在工作区中,没有被添加到暂缓区
  • 文件显示为绿色:添加的文件已经添加到暂缓区中,这种状态下的文件就可以被提交到代码仓库中了

5.修改文件

$ open main.m

6.将工作区中的文件添加到暂缓区中

$ git add main.m
  • 要是想将所有文件添加到暂缓区中

    $ git add .

7.给git命令起别名

$ git config alias.st "status"
$ git config alias.ci "commit -m"
  • alias.后面是别名," "中的是被起别名的命令

8.查看历史版本

$ git log
$ git reflog
  • git版本号是由sha1加密算法生成的一个40位的哈希码
  • 7c4a8d09ca3762af61e59520943dc26494f8941b

9.版本回退

$ git reset --hard HEAD  重置到当前版本
$ git reset --hard HEAD^ 重置到上个版本
$ git reset --hard HEAD^^  重置到上上个版本
$ git reset --hard HEAD~1024 重置到往上1024个版本
$ git reset --hard git版本号前7位 重置到指定版本

10.--global的作用(可以用来配置全局的用户名和密码)

$ git config --global user.name "username"
$ git config --global user.email "useremail@gmail.com"

三. 团队开发

在团队开发程序时就需要创建一个代码共享库
1.创建代码共享库(让一个文件成为共享库)

$ git init --bare

2.A将共享代码仓库中的内容clone下来

$ git clone 代码共享库的地址

3.A初始化项目

操作流程

4.B也开始进行开发

操作流程

  • git clone 共享代码库的地址
  • 修改代码或者文件
  • git commit
  • git push

注意:

  • 同一个文件的共享
  • 同一个文件共享时发生的代码冲突
  • 创建新文件的共享
  • storyboard的共享(仅限iOS开发)
  • 静态库的共享(不需要像类似svn一样执行add命令)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352

推荐阅读更多精彩内容