如今有這樣一種情形:有一個叫作Joe的程序猿寫了一個遊戲程序,而你可能要去改進它。而且Joe將他的代碼放在了GitHub倉庫上。下面是你要作的事情:遊戲
fork而且更新GitHub倉庫的圖表演示同步
Fork他的倉庫:這是GitHub操做,這個操做會複製Joe的倉庫(包括文件,提交歷史,issues,和其他一些東西)。複製後的倉庫在你本身的GitHub賬號下。目前,你本地計算機對這個倉庫沒有任何操做。工作流
Clone你的倉庫:這是Git操做。使用該操做讓你發送"請給我發一份我倉庫的複製文件"的命令給GitHub。如今這個倉庫就會存儲在你本地計算機上。it
更新某些文件:如今,你能夠在任何程序或者環境下更新倉庫裏的文件。class
提交你的更改:這是Git操做。使用該操做讓你發送"記錄個人更改"的命令至GitHub。此操做只在你的本地計算機上完成。基礎
將你的更改push到你的GitHub倉庫:這是Git操做。使用該操做讓你發送"這是個人修改"的信息給GitHub。Push操做不會自動完成,因此直到你作了push操做,GitHub才知道你的提交。request
給Joe發送一個pull request:若是你認爲Joe會接受你的修改,你就能夠給他發送一個pull request。這是GitHub操做,使用此操做能夠幫助你和Joe交流你的修改,而且詢問Joe是否願意接受你的"pull request",固然,接不接受徹底取決於他本身。程序
若是Joe接受了你的pull request,他將把那些修改拉到本身的倉庫。勝利!im
Joe和其他貢獻者已經對這個項目作了一些修改,而你將在他們的修改的基礎上,還要再作一些修改。在你開始以前,你最好"同步你的fork",以確保在最新的複製版本里工做。下面是你要作的:圖表
同步GitHub fork的圖表示意圖
從Joe的倉庫中取出那些變化的文件:這是Git操做,使用該命令讓你能夠從Joe的倉庫獲取最新的文件。
將這些修改合併到你本身的倉庫:這是Git操做,使用該命令使得那些修改更新到你的本地計算機(那些修改暫時存放在一個"分支"中)。記住:步驟1和2常常結合爲一個命令使用,合併後的Git命令叫作"pull"。
將那些修改更新推送到你的GitHub倉庫(可選):記住,你本地計算機不會自動更新你的GitHub倉庫。因此,惟一更新GitHub倉庫的辦法就是將那些修改推送上去。你能夠在步驟2完成後當即執行push,也能夠等到你作了本身的一些修改,並已經本地提交後再執行推送操做。
比較一下fork和同步工做流程的區別:當你最初fork一個倉庫的時候,信息的流向是從Joe的倉庫到你的倉庫,而後再到你本地計算機。可是最初的過程以後,信息的流向是從Joe的倉庫到你的本地計算機,以後再到你的倉庫。