九色国产,午夜在线视频,新黄色网址,九九色综合,天天做夜夜做久久做狠狠,天天躁夜夜躁狠狠躁2021a,久久不卡一区二区三区

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
學一點Git--20分鐘git快速上手

日中天的今天,不懂git都不好意思跟人說自己是程序猿。你是不是早就躍躍欲試了,只是苦于沒有借口(契機)。 好吧,機會就在今天。 給我20分鐘,是的,只要20分鐘, 讓你快速用上git。

我們廢話不多說,直接來干貨。

我們將會介紹以下幾點:

一, 什么是git

二,使用git的一般開發(fā)流程

三,快速安裝新建項目。holloworld。

開始:

一,什么是git。

閱讀本文的前提是你知道或者用過至少一種源代碼管理工具,比如:SVN, CVS 或者TFS等等。 你必須知道什么是源代碼管理。如果這些都不滿足。請直接跳過本文。

了解陌生事物的最好辦法,是和已知事物類比。 ---孔子

我們以svn為例。  我們都知道傳統(tǒng)的源代碼管理都是以服務(wù)器為中心的:

每個開發(fā)者都直接連在中間服務(wù)器上, 本地修改,然后commit到svn服務(wù)器上。

這種做法看似完美,但是有致命的缺陷:

1. 開發(fā)者不能本地跟蹤代碼版本。 所有的信息都是在服務(wù)器上。  你把本地的代碼改了很多,但是又不能提交。通常,本地只能緩存一個版本。對于小項目無所謂, 但是項目一復(fù)雜,人員多就麻煩了。 通常你本地的代碼都全是紅色的。自己都不知道今天修改了什么, 有哪些修改是真正應(yīng)該提交給svn的。

2. 因為第一點,一旦離開服務(wù)器, 程序猿將無法正常工作。 因為本地不能跟蹤代碼版本。  你的(幾乎)任何操作都必須連上服務(wù)器。比如, show log, blame,show history等等。

3. 中央服務(wù)器壓力過大。  因為每個人都必須把代碼提交到服務(wù)器,并且做daily build。

4. 對于大型項目, svn幾乎不可用。 例如linux內(nèi)核項目, 開發(fā)者何止幾萬? 都直接提交給svn服務(wù)器的話還不亂套了。

5. 對于個人的私人項目而言(或者對于小公司的項目), 不用版本控制當然不行,但是為了用版本控制而專門架設(shè)svn服務(wù)器有有點舍不得。

有沒有能解決上述幾個問題的東東呢?  恩, 答案是肯定的。

Linux內(nèi)核的作者也遇到了這些問題,于是他決定再一次改變世界, 重寫一個可以本地使用的svn。

對, 這就是git。  分布式代碼版本管理系統(tǒng)。(說人話 :就是不用服務(wù)器的svn)

我們來看git的結(jié)構(gòu):

git沒有中央服務(wù)器。 你裝上git軟件之后,你就可以指定本地的文件夾進行版本控制了。你可拔掉網(wǎng)線,然后在本地修改, commit,revert(rollback), branch, restore, show log, blame, history 等等, 全部你之前在svn里面可以用的操作。 簡單的說,你就完美了。

 

你可能意識到一個問題了。   就是天下大亂了。

每個人都自顧自的開發(fā),怎么協(xié)作呢?  恩,通常git比svn會多出兩個操作, 就是 pull 和push。

我們看一個復(fù)雜一點的圖:

開發(fā)者之間通過 pull和push操作, 把別人的修改拉過來,或者把自己的修改推給別人。

恩,你可能還是覺得有問題,我們生產(chǎn) 環(huán)境中, 以誰的代碼為最終版本呢? 

這個問題確實比較棘手,因為,從單純的技術(shù)上講,每個開發(fā)者的機器都是對等的。 沒有主次之分。

我們還有辦法:

技術(shù)上不能解決的問題,我們從制度上解決. ---- 孟子

從分布式環(huán)境中我們模擬出一個中心來:

我們引入Leader這個角色。  他的機器是最終版本。 每個開發(fā)者都必須把最終的修改版push給leader。 leader會review然后提交。他就是最終版本。

恩, 我們好像還漏掉一個大問題, 說git,怎么漏掉了github呢。 github是什么。

我們知道,如果每個人都本地修改的話,本地可能不安全,(硬盤壞了,筆記本被偷了。。。。)

我們可能需要一個安全的服務(wù)器來存儲/備份代碼。對于開源的項目,可能是需要一個地方分享你的代碼,你不可能24小時開著筆記本,讓別人從你這pull代碼。

于是, 網(wǎng)上所謂的源代碼托管網(wǎng)站就冒出來了。 github就是這樣的。

看這個圖, 我只修改了其中一個地方, 就是把leader的機器換成了。 github.com 提供的在線賬戶。

所以, git和 github沒有必然聯(lián)系。

這里有幾個常用的在線托管地址, 有興趣自己看看:

1. github.com,  大名鼎鼎。 免費,只支持開源項目, 不支持私有項目。

2.  bitbucket.com ,同樣大名鼎鼎。 免費, 支持開源項目和私有項目。 免費用戶最多5個。項目無限。

3.   git.oschina.net, 國內(nèi)頂尖托管平臺, 我本人正在用的就是這個。  支持開源項目和私有項目。 成員無限, 項目1000個。   使用的是阿里云服務(wù)器, 速度極快。  本人推薦5顆星。

 

二, git開發(fā)的一般流程。

上面其實已經(jīng)涉及了使用git的一般結(jié)構(gòu)。 那么生產(chǎn)環(huán)境中, git是如何應(yīng)用的呢。

本人知道的模型如下:

 

每個開發(fā)者都向自己的項目服務(wù)器(leader)提交代碼, leader向公司服務(wù)器提交。 當然這個leader是可有可無的。如果項目小的話,  開發(fā)者可以直接向公司服務(wù)器提交。  公司的服務(wù)器就是最終版本。  一般公司還會有持續(xù)集成CI服務(wù)器。  我們可以在公司的源碼服務(wù)器上設(shè)置git的hook。 自動觸發(fā)CI服務(wù)器工作。 這是后話,不多說了。

 

三,  前面的概念弄清楚之后, 上手就容易多了。 我們helloworld。

1.   這是git的官網(wǎng):http://git-scm.com/  去下載windows客戶端。

     如果是linux的話, sudo apt-get install gitcore

2.  注意, 官網(wǎng)的客戶端都是命令行的。 命令行是高階用法。不在這里說了。 我們下個gui。

我用的是TortoiseGit。  https://code.google.com/p/tortoisegit/  , 大家恐怕都熟悉svn時代的烏龜爬。上手快。 我們下面的操作都是gui上的。

安裝過程不說了。 一路next。 我們跳過。 直接到最后。假設(shè)你現(xiàn)在已經(jīng)安裝完成了。

比如我已經(jīng)有一個工程, helloworld:

這是工程文件的內(nèi)部結(jié)構(gòu):

現(xiàn)在我們想讓helloworld用上git怎么做呢, 在工程根目錄下,點擊鼠標右鍵。

選擇 Create repository。

這個選項不要勾上。 稍后我們會解釋什么是 Bare。

然后就完成了。

里面多出了一個 .git目錄。 當前的目錄(及其所有子目錄)已經(jīng)在git的監(jiān)視之中了。 但是當前的代碼還沒有添加到git的跟蹤數(shù)據(jù)庫中。  簡單的說,git還沒有儲存任何版本信息。 我們需要進行第一次提交:

git默認你本地會有一個主分支master。

我們寫一些注釋, 并且勾上想要添加到git的文件。 (如果有子目錄的話, 它都會顯示在這里。)

提交完成, close。 這個push按鈕,稍后再說。

好了,這個時候我們在回到文件夾,看看有什么變化:

 

現(xiàn)在這些文件就添加進git了。

剩下的你就可以為所欲為了。 像svn一樣,自己試試幾個命令吧: 修改, difference, commit, revert,

到這你已經(jīng)入門了。 

最后我們來介紹兩個重要的概念。

1. “git目錄”,   就是指上圖中,項目根目錄下生成的 “.git” 文件夾。  用過svn的同學都知道, svn有‘.svn’文件夾。  他們的作用差不多。 這里保存了git的本地數(shù)據(jù)庫資料。就是所有的版本信息。   跟svn不一樣的地方就是,git中,只有根目錄下有這個目錄, 所有的子目錄下都沒有, 也就是每個工程只有一個.git目錄。

2.  “git工作目錄”, 其實就是你的工程目錄, 比如上圖中的工程根目錄:H:\mycode\helloworld\  。  為什么有這個工作目錄呢。 就是你工作在這個目錄下, 你可以修改編輯里面的文件,最后把修改提交給git目錄。  這個共工作目錄還有一個神奇的地方就是,  你可以創(chuàng)建不同的branch(你默認工作在master下), 當你切換不同的branch時, 你的工作目錄(工程目錄)里的所有文件都會變成當前branch對應(yīng)的文件。 這個不展開了。

 

最后再解釋上面留下的兩個問題:

1. “Bare”  創(chuàng)建Bare的意思是: 你只想要git的數(shù)據(jù)庫(即上圖中的 “.git”文件夾。), 而不想要當前的文件。 這通常用在公司的中央服務(wù)器上。 它不需要當前項目的實際代碼,只需要保留git數(shù)據(jù)庫信息就行了。

2. 在commit之后的對話框中的 push的意思。   正如之前介紹的。 push的意識是把你的修改push給別人(或者給公共服務(wù)器)。  commit的意思只是提交到本地的 .git 數(shù)據(jù)庫。 并沒有更新給別人。  所以提交完之后, 烏龜很貼心的給我們一個push按鈕。 通過它你可以快速把剛剛的修改push給別人,或者給服務(wù)器。 

 

總結(jié), 這不是一本完全的git手冊,但至少能讓你消除git恐懼癥,快速入手。

 

這里是gitbook的中文版: http://gitbook.liuhui998.com/  他是真正的大而全。 為什么最后才說它呢? 因為它就像是一本 牛津大辭典, 全面,權(quán)威。  但是對于幼兒園小朋友學英語,就不能一上來就背它吧。  先跟著別人說,上手要緊。   之后有什么不會的,再去查字典。

 

好了。 就到這。 歡迎大家訪問我的個人獨立博客: http://blog.byneil.com  歡迎大家多多交流。

后面有時間的話,還想給大家分享一下我使用幾大源碼托管服務(wù)器的經(jīng)驗。 希望大家頂啊。。。。

本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
git團隊開發(fā)使用
如何理解Git的分布式?
Git最新版從零開始詳細教程(迅速搞定~)
Git介紹,安裝,Git+Git flow使用
Walle,一個開源的web代碼發(fā)布管理系統(tǒng)
[譯] 關(guān)于 Git 你需要知道的一些事情
更多類似文章 >>
生活服務(wù)
熱點新聞
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服