git 命令詳解和常見問題解決

功能一 提交:1:git init           # 初始化,表示即將對當前文件夾進行版本控制2:git status         # 查看Git當前狀態,如:那些文件被修改過、那些文件還未提交到版本庫等。3:git add .          # 添加當前目錄下所有文件到版本庫4:git commit -m "第一次提交"   # 提交到版本庫,并填寫版本說明,以便以后回滾   5:git log            # 查看版本庫的日志功能二 版本回滾:1:git add              # 增加2:git commit -m "..."  # 增加到版本庫3:git log              # 查看版本庫的日志4:git reset --hard     # 切換到功能一1:git reflog           # 查看所有的版本庫2:git reset --hard     # 切換到功能一突然有bug需要改
解決方案一 stash:1:git add             # 增加2:git commit -m "..." # 增加到版本庫    3:git log             # 查看版本庫的日志        # 繼續開發,發現之前上線的代碼需要修改,把現在的代碼保存。1:git stash          # 現在開發的代碼,保存# 完成功能一,增加到版本庫,提交,繼續開發之前的功能,發生沖突手動解決沖突1:git stash pop       # 將第一個記錄從“某個地方”重新拿到工作區(可能有沖突,需手動解決)2:git add .           # 增加到版本庫3:git commit -m "..." # 增加到版本庫,提交stash 用法:git stash        # 將當前工作區所有修改過的內容存儲到“某個地方”,將工作區還原到當前版本未修改過的狀態git stash list   # 查看“某個地方”存儲的所有記錄git stash clear  # 清空“某個地方”git stash pop    # 將第一個記錄從“某個地方”重新拿到工作區(可能有沖突)git stash apply  # 編號,將指定編號記錄從“某個地方”重新拿到工作區(可能有沖突) git stash drop   # 編號 ,刪除指定編號的記錄  解決bag方法二:(分支)1:git branch dev    # 創建dev分支 2:git branch -d dev # 刪除分支 3:git checkout dev  # 切換分支 4:git merge dev     # 分支合并    
修復Bug流程:git branch dev      # 創建dev分支 git checkout dev    # 切換分支# 寫代碼git add .           # 增加到版本庫git commit -m 'xxx' # 提交,不合并到master# 切換mastergit checkout master # 切換master git branch bug      # 創建bug分支 git chekcout bug    # 切換到bug分支# 修復bug git add .           # 增加到版本庫git commit -m '緊急修復bug'  # 提交# 切換master分支git checkout master # 切換master git merge bug       # 合并分支# 刪除bug分支git branch -d bug   # 刪除bug分支 # 切換dev分支git checkout dev # 繼續開發

git 全局配置

t config --global user.name "fenglepeng"
git config --global user.email "fenglepeng@163.com"

克隆一個新的倉庫

git clone https://github.com/flepeng/flepeng.github.io.git
cd flepeng.github.io
touch README.md
git add README.md
git commit -m "add README"
git push -u origin master
Username?for?'https://github.com':??????????????????????????# 輸入GitHub用戶名
Password?for?'https://flp@github.com':??????????????????    # 輸入GitHub密碼

將一個本地文件夾推送到倉庫

cd existing_folder
git init
git remote add origin https://github.com/flepeng/flepeng.github.io.git
git add .
git commit -m "Initial commit"
git push -u origin master

將一個本地倉庫重命名之后推送到新的倉庫

cd existing_repo
git remote rename origin old-origin
git remote add origin https://github.com/flepeng/flepeng.github.io.git
git push -u origin --all
git push -u origin --tags

另一種拉取策略

另一種拉取策略:git init  git remote add origin https://github.com/flp/test.gitgit fetch origin master git merge origin/master 提交遠程代碼git pull origin master git fetch origin master 

強行push?

# 如果本地和遠程的庫屬于兩個庫,而你強行管理上之后,這時你無論 push 和 pull 都會報錯
# ‘fatal: refusing to merge unrelated histories’此時需要
git pull origin?master?--allow-unrelated-histories
# 此時,兩個庫的文件會并存,之后就可以處理了,或者你可以使用
$ git push -u origin master -f?
# 強制提交,但是會丟失遠程的代碼,慎用

分支(branch)操作相關命令

$ git branch              # 查看本地分支
$ git branch -r           # 查看遠程分支
$ git branch [name]       # 創建本地分支,注意新分支創建后不會自動切換為當前分支
$ git checkout [name]     # 切換分支
$ git checkout -b [name]  # 創建新分支并立即切換到新分支
$ git branch -d [name]    # 刪除分支,-d選項只能刪除已經參與了合并的分支,對于未有合并的分支是無法刪除的。如果想強制刪除一個分支,可以使用-D選項
$ git merge [name]        # 合并分支,將名稱為[name]的分支與當前分支合并
$ git push origin [name]  # 創建遠程分支(本地分支push到遠程)
$ git push origin :heads/[name] 或 $ git push origin :[name]  # 刪除遠程分支$ git push -u origin dev??# 加了參數-u后,以后即可直接用git push 代替git push origin master
$ git push origin         # 將當前分支推送到origin主機的對應分支。
$ git push                # 如果當前分支只有一個追蹤分支,那么主機名都可以省略。?

遠程提交,不用輸入用戶名密碼

# 第一步, --global 為所有的git 都設置使用下次輸入的賬號密碼,不推薦使用此參數
git config --global credential.helper store# 第二步,執行這步會讓你輸入用戶名密碼,后面再執行這條命令就都不用在輸入了
git pull

原理:會在 用戶根目錄下產生如下兩個文件,.gitconfig (記錄用戶名信息)和 .git-credentials(用戶名密碼) 用以記錄當前操作用戶,文件內容就是公鑰信息。

問題解析

error: failed to push some refs to 'https://github.com/xxxx.git'

問題展示:

解決辦法:

1: 進行push前先將遠程倉庫pull到本地倉庫
$ git pull origin master    #git pull --rebase origin master
$ git push -u origin master2: 強制push本地倉庫到遠程 (這種情況不會進行merge, 強制push后遠程文件可能會丟失 不建議使用此方法)
$ git push -u origin master -f3: 避開解決沖突, 將本地文件暫時提交到遠程新建的分支中
$ git branch [name]
# 創建完branch后, 再進行push
$ git push -u origin [name]

error: src refspec master does not match any

問題解析:

引起該錯誤的原因是,目錄中沒有文件,空目錄是不能提交上去的

解決方法

git add README 
git commit -m 'first commit'
git push origin master

GIT刷新忽略文件.gitignore

# 1、重置所有緩存(注意后面有個.)
git rm -r --cached .# 2、重新添加(注意后面有個.)
git add .# 3、提交
git commit -m ".gitignore is now working"

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/454374.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/454374.shtml
英文地址,請注明出處:http://en.pswp.cn/news/454374.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

辭職日記----記錄31歲的程序員跳槽心態

vcleaner http://topic.csdn.net/u/20080626/23/8f6a8ecc-c072-43ee-bf2d-7ac2286b6805.html http://topic.csdn.net/u/20080704/23/858fc00d-ec14-4db7-93be-34903b7f157a.html 轉載他的離職日記,有許多東西值得我們認真思考,人活著到底為了什么&a…

從Android源碼的角度分析Binder機制

IPC 為了弄懂IPC的來龍去脈,我將從以下三個方面為大家來講解,希望對大家理解IPC會有幫助 什么是IPC IPC是Inter Process Communication的縮寫,其意思就是進程間的通信,也就是兩個進程之間的通信過程。我們都知道在Android系統中&a…

excel vba 調用webbrowser_VBA 公式與函數

一, 在單元格中輸入公式的3種方法:1) 用VBA在單元格中輸入普通公式Sub formula_1() Range("d2") ("B2 * C2") End Sub運行程序后,在D2的單元格內顯示的是公式 B2 * C2 ,并非程序返回值.下文(二)中會介紹另外一種直接返回值的方式想要通過程序一…

內部類可以引用它的包含類的成員嗎?有沒有什么限制?

最近看到一道面試題:內部類可以引用它的包含類的成員嗎?有沒有什么限制? 答案大部分都是這樣子的: 完全可以。如果不是靜態內部類,那沒有什么限制! 一個內部類對象可以訪問創建它的外部類對象的成員包括私有…

松下NPM服務器怎么備份系統,松下(Panasonic)-NPM校正amp;CPK完整版教程,一步步帶你成為SMT設備大神!...

馬上注冊,結交更多技術專家,享用更多功能,讓你輕松解決各種三星貼片機問題您需要 登錄 才可以下載或查看,沒有帳號?立即注冊 xa8f80375060fa05b8aebe69ffa21080c.gif (5.26 KB, 下載次數: 3)2019-8-12 00:02 上傳f5aae…

Python 模塊之科學計算 Pandas

目錄 一、Pandas簡介 數據結構 二、Series series 的創建 Series值的獲取 Series的運算 Series缺失值檢測 Series自動對齊 Series及其索引的name屬性 三、DataFrame 創建 Index對象 通過索引值或索引標簽獲取數據 自動化對齊 四、文件操作 文件讀取 數據庫數據…

根據 設備名(br0/eth0/em0)稱獲取 當前機器的IP地址與子網掩碼信息

#!/usr/bin/env python 根據 設備名(br0/eth0/em0)稱獲取 當前機器的IP地址與子網掩碼信息import socket, struct, fcntldef get_ipaddress(ifname eth0):s socket.socket(socket.AF_INET, socket.SOCK_DGRAM)return socket.inet_ntoa(fcntl.ioctl(s.fileno(),0x8915, # SI…

我的程序生涯

本文僅為愛好程序及向往真正之程序員者所作,其余人等可忽略下文。 如今,接觸CS幾近八年,不學無術,所精之物鮮也,以至一事無成。 現回憶吾程序之生涯,以整理繁雜之心緒。 1. 接觸計算機和編程語言 02年始大…

機器學習中qa測試_如何對機器學習做單元測試

作者:Chase Roberts編譯:ronghuaiyang導讀養成良好的單元測試的習慣,真的是受益終身的,特別是機器學習代碼,有些bug真不是看看就能看出來的。在過去的一年里,我把大部分的工作時間都花在了深度學習研究和實…

項目寶提供的服務器,開源WebSocket服務器項目寶貝魚CshBBrain V4.0.1 和 V2.0.2發布

開源WebSocket服務器項目寶貝魚CshBBrain V4.0.1 和 V2.0.2發布更新的功能列表如下:1.解決開啟廣播消息開關時,不能同時接入2個客戶端的重大缺陷。2.對廣播消息做了重大優化,從以前一個線程發送廣播消息進化到使用工作線程池中的線程并行的發…

c# 無損高質量壓縮圖片代碼

/// 無損壓縮圖片 /// <param name"sFile">原圖片</param> /// <param name"dFile">壓縮后保存位置</param> /// <param name"dHeight">高度</param> /// <param name"dWidth"…

一個從文本文件里“查找并替換”的功能

12345678910111213141516171819202122232425# -*- coding: UTF-8 -*-file input("請輸入文件路徑:") word1 input("請輸入要替換的詞:") word2 input("請輸入新的詞&#xff1a;") fopen(file,"r") AAAf.read() count 0 def BBB()…

機器學習算法之 KNN

K近鄰法(k-nearst neighbors,KNN)是一種很基本的機器學習方法了&#xff0c;在我們平常的生活中也會不自主的應用。比如&#xff0c;我們判斷一個人的人品&#xff0c;只需要觀察他來往最密切的幾個人的人品好壞就可以得出了。這里就運用了KNN的思想。KNN方法既可以做分類&…

安裝云端服務器操作系統,安裝云端服務器操作系統

安裝云端服務器操作系統 內容精選換一換SAP云服務器規格在申請SAP ECS之前&#xff0c;請參考SAP標準Sizing方法進行SAPS值評估&#xff0c;并根據Sizing結果申請云端ECS服務器資源&#xff0c;詳細信息請參考SAP Quick Sizer。SAP 各組件最低硬盤空間、RAM&#xff0c;以及軟件…

python 進度條_六種酷炫Python運行進度條

轉自&#xff1a;一行數據閱讀文本大概需要 3 分鐘你的代碼進度還剩多少&#xff1f;今天給大家介紹下目前6種比較常用的進度條&#xff0c;讓大家都能直觀地看到腳本運行最新的進展情況。1.普通進度條2.帶時間進度條3.tpdm進度條4.progress進度條5.alive_progress進度條6.可視…

js 獲取多少天前

getBeforeDate: function(day, str) { var now new Date().getTime(); //獲取毫秒數 var before new Date(now - ((day > 0 && day ? day : 0) * 86400 * 1000)); var year before.getFullYear(); var month before.getMonth()1; var date before.getDate(); …

程序員的基本素質

給所有立志成為程序員的朋友 以及 自勉之&#xff01; 程序員基本素質&#xff1a; 作一個真正合格的程序員&#xff0c;或者說就是可以真正合格完成一些代碼工作的程序員&#xff0c;應該具有的素質。 1&#xff1a;團隊精神和協作能力 把它作為基本素質&#xff0c;并…

權限之淺理解

白馬過隙&#xff0c;在感嘆時光流逝的同時不得不承認在學習中隨著知識面的不斷擴展所接受的東西也越來越多&#xff0c;尤其是那些外形比較容易混淆的命令&#xff0c;著實讓作為新手的吃了很多苦頭&#xff0c;趁著學習緊張之時偷個懶整理這周易混淆的命令&#xff1a; chgrp…

機器學習算法之生成樹

一、什么是決策樹&#xff1f; 決策樹&#xff08;Decision Tree&#xff09;是一種基本的分類和回歸的方法。 分類決策樹模型是一種描述對實例進行分類的樹形結構。決策樹由結點&#xff08;node&#xff09;和有向邊&#xff08;directed edge&#xff09;組成。結點有兩種…

強烈推薦給從事IT業的同行們 (轉載)

作者&#xff1a;李學凌 文章來源&#xff1a;bbs.ustc.edu.cn 中國有很多小朋友&#xff0c;他們18,9歲或21,2歲&#xff0c;通過自學也寫了不少代碼&#xff0c;他們有的代碼寫的很漂亮&#xff0c;一些技術細節相當出眾&#xff0c;也很有鉆研精神&#xff0c;但是他…