git 基本使用

来源:http://www.cnblogs.com/XL-Sunny/archive/2016/08/18/5783614.html
-Advertisement-
Play Games

簡單幾步操作讓你在終端下用git實現文件的上傳。 一、克隆項目 在工作中,常見的情景都是遠程庫已經建好了,需要大家把代碼拉下來,共同協作開發。本文所有操作均在終端下進行。 //克隆一個本地庫 git clone 你的遠程倉庫地址 二、本地庫的操作 //添加修改 1、git add 修改的文件名 // ...


  簡單幾步操作讓你在終端下用git實現文件的上傳。

一、克隆項目
    在工作中,常見的情景都是遠程庫已經建好了,需要大家把代碼拉下來,共同協作開發。本文所有操作均在終端下進行。
    //克隆一個本地庫
    git clone 你的遠程倉庫地址   

二、本地庫的操作
   //添加修改
    1、git add 修改的文件名
     //提交修改內容
    2、git commit -m "修改備註"

三、把修改的內容提交到遠程庫
    //第一次推送,加上-u參數,以後推送可省略
     git push -u origin master   

就這簡單幾步,就能實現你的代碼上傳到遠程倉庫啦。如果你還有其他更多需求,可以繼續往下看。

 
四、其他經常用到的操作
  1、基本操作     

  //用Xcode打開文件
     open -a Xcode 文件名  

     //隨時掌握工作區的狀態
     git status

    //查看文件的修改內容
    git diff  文件名

  2、版本管理
    //版本回退到上一個版本,HEAD表示最新版本
    git reset --hard HEAD^

    //版本回退到上上一個版本
    git reset --hard HEAD^^

    //查看提交歷史,可以看到不同版本的commit_id
    git log   //出來的信息較全較多,下麵的命令出來的簡略點
    git log --pretty=oneline   

    //查看命令歷史,以便確定回到未來的哪個版本
    git reflog   

    //版本回退到指定版本,commit_id
    git reset --hard commit_id  

 3、修改和刪除操作
    //可以丟棄工作區的修改,-- 很重要,不能少,否則會變成“切換到另一個分支”
    git checkout -- 文件名   

   //把暫存區的修改撤銷掉,重新放回工作區
    git reset HEAD 文件名   

    //刪除文件
    git rm 文件名   

  4、分支管理
    git 推薦使用分支完成某個任務,合併後再刪掉分支。這樣過程更安全
     1)創建並切換到分支,-b 表示創建並切換
        git checkout -b 分支名字
        等於兩條命令: git branch 分支名字     //創建分支
                    git checkout 分支名字     //切換到分支   

    2)列出所有分支,當前分支前面會標一個*號
        git branch

    3)在分支上進行修改等操作
        git add 文件名
        git commit -m "修改備註"

     4)分支工作完成,切換回master分支,把分支工作成果合併到master分支上,然後刪除分支
       git checkout master
       git merge 分支名字
       git branch -d 分支名字      

        合併分支時,git會優先用Fast forward模式,這種模式下,刪除分支後,會丟掉分支信息。
       強制禁用Fast forward模式,git就會在merge時生成一個新的commit,這樣,從分支歷史上就可以看出分支信息
        //--no-ff參數,表示禁用Fast forward
       git merge --no-ff -m "merge with no-ff" 分支名字

     5)發生衝突的話需要手動進行修改,在提交合併
      //可以看到分支合併圖
      git log --graph
   
    在實際開發中,我們應該按照幾個基本原則進行分支管理:
  1、master分支應該是非常穩定的,也就是僅用來發佈新版本,平時不能在上面幹活
    2、那在哪幹活呢?幹活都在自己建的分支上
    3、你和你的小伙伴們每個人都有自己的分支,時不時地往分支上合併就可以了
  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、前言 瞭解了簡單圖文混排 (屬性字元串的使用)及 正則表達式的部分知識,為了加深印象,寫了個簡單表情鍵盤demo 展示文字用的是 UITextView 由於時間匆忙,存在一些bug,以及不完善的地方,僅作為小demo 練習一下 圖文混排可以用 TextKit ,下次有時間學習下 環境 xcode ...
  • 菜單事件包括,剪切、拷貝、全選、分享...,此 demo 只有 copy、share 1.定義 field 繼承與 UITextField 2.ViewController 載入 3.分享的實現,以微信為例,準備工作在這裡 完成demo 在 githud,點我查看 ...
  • title: EditText 基本用法 tags: EditText,編輯框,輸入框 EditText介紹: EditText 在開發中也是經常用到的控制項,也是一個比較必要的組件,可以說它是用戶跟Android應用進行數據傳輸的窗戶,比如實現一個登陸界面,需要用戶輸入賬號密碼,然後我們獲取用戶輸入 ...
  • 一、封裝 封裝:隱藏對象的屬性和實現細節,僅對外公開介面,控製程序中屬性的讀和修改的訪問級別。 person.h: person.m: 優點: 1. 隱藏內部實現細節,設置訪問許可權,提高了數據的安全性。 2. 任何出入的數據都要流經介面,通過重寫set方法可以起到過濾數據的作用。 二、繼承 繼承:指 ...
  • Android Weekly Issue #218, 筆記. ...
  • 自定義View的第二個學習案例,使用ViewPage實現廣告輪播,通過組合現有的View實現效果如下: 有關ViewPage使用可以學習谷歌官方API,和訓練案例: 1.使用ViewPage實現屏幕滑動:https://developer.android.com/training/animation ...
  • 前言:今天在寫代碼的過程中遇到一個需要修改系統navigationBar的背景色,我起初用的是barTintColor去修改但是防不住系統點擊按鈕的時候會有一個渲染高亮的效果,調了好久沒有達到自己想要的效果,最後放棄用顏色來搞這個了,看了一下swift的API發現也可以用圖片,有不好意思找UI(自己 ...
  • 序言 打算分享一些有爭議的話題,並且表達一下我的看法。這是該系列的第一篇,我想討論的是:類的成員變數應該如何定義? 在 Objective-C 的語言的早期,類的私有成員變數是只能定義在 .h 的頭文件裡面的。像如下這樣: 之後,蘋果改進了 Objective-C,允許在 .m 裡面添加一個當前類的 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...