git仓库的基本用法

一、简介

git是一个免费的、开源的分布式版本控制系统,可以快速高效地处理从小型到大型的项目。git很容易学习,而且它的占用资源很小,性能也非常好。它超越了subversion、cvs、perforce和clearcase等scm工具,具有廉价的本地分支、方便的暂存区域和多个工作流等特性。[git 官网]

分布式相比于集中式的最大区别在于开发者可以提交到本地,每个开发者通过克隆(git clone),在本地机器上拷贝一个完整的Git仓库。Git的功能特性[git-百度百科]:

  1. 克隆完整的Git仓库
  2. 创建分支,修改代码。
  3. 分支上提交代码。
  4. 合并分支。
  5. 服务器主分支合并fetch。
  6. 生成补丁patch。

二、安装

tortoiseGit是一个开放的git版本控制系统的源客户端,该软件功能和git一样。git是命令行操作模式,tortoiseGit界面化操作模式,不用记git相关命令就可以直接操作。当然安装git后也可以采用git GUI进行操作。下载链接如下:

git: https://git-scm.com/downloads

tortoisegit: https://tortoisegit.org/download/

三、启动Git

安装好git后,可以在代码工程文件夹进行鼠标右键,选择Git GUI here 或者Git Bash here分别采用GUI 和 Bash命令窗口打开Git.

例如:

四、常用命令

4.1 创建git代码仓库 init


git init # 在当前目录新建一个Git代码库git init [project-name] # 新建一个目录,将其初始化为Git代码库

4.2 添加配置文件config

Git 自带一个 git config 的工具来帮助设置控制 Git 外观和行为的配置变量。 这些变量存储在三个不同的位置:

  1. /etc/gitconfig 文件: 包含系统上每一个用户及他们仓库的通用配置。 如果使用带有 --system 选项的 git config 时,它会从此文件读写配置变量。

  2. ~/.gitconfig 或 ~/.config/git/config 文件:只针对当前用户。 可以传递 --global 选项让 Git 读写此文件。

  3. 当前使用仓库的 Git 目录中的 config 文件(就是 .git/config):针对该仓库。

每一个级别覆盖上一级别的配置,所以 .git/config 的配置变量会覆盖 /etc/gitconfig 中的配置变量。在 Windows 系统中,Git 会查找 $HOME 目录下(一般情况下是 C:\Users\$USER)的 .gitconfig 文件。 Git 同样也会寻找 /etc/gitconfig 文件,但只限于 MSys 的根目录下,即安装 Git 时所选的目标位置。在用户主目录下默认为全局配置,也可以在项目目录下作为项目配置。非必须。

git config [--global] user.name "[name]" # 设置提交代码时的用户信息
e.g. git config --global user.name "jianwang16"git config [--global] user.email "[email address]"# 设置提交代码时的email
e.g. git config --global user.email "jainwang16@foxmail.com"

4.3 添加或删除暂存区代码add rm

git add [file1] [file2] ... # 添加指定文件到暂存区
e.g. git add a.c b.c git add [dir] # 添加指定目录到暂存区,包括子目录
e.g git add pro/codegit add . # 添加当前目录的所有文件到暂存区git rm [file1] [file2] ... # 删除工作区文件,并且将这次删除放入暂存区
e.g. git rm a.c b.cgit rm --cached [file] # 停止跟踪某文件
e.g. git rm --cached a.cgit mv [file-original] [file-renamed] # 文件改名,并且将这个改名放入暂存区
e.g. git mv a.c amodify.c

4.4 提交代码commit

git commit -m [message] # 提交暂存区到仓库区
e.g. git commit -m "20180808 v1 新增文件file1"git commit [file1] [file2] ... -m [message] # 提交暂存区的指定文件到仓库区
e.g. git commit a.c b.c -m "20180808 V2 新增文件a.c b.c"git commit -a # 提交所有直接到仓库区-a = all git commit -v # 提交时显示所有diff信息git commit --amend -m [message] # 使用一次新的commit,替代上一次提交

4.5 创建分支branch

git branch # 列出所有本地分支git branch -r # 列出所有远程分支git branch -a # 列出所有本地分支和远程分支git branch [branch-name] # 新建一个分支,但依然停留在当前分支git checkout -b [branch] # 新建一个分支,并切换到该分支git branch [branch] [commit] # 新建一个分支,指向指定commitgit branch --track [branch] [remote-branch]  # 新建一个分支,与指定的远程分支建立追踪关系git branch -d [branch-name] # 删除分支git push origin --delete [branch-name] # 删除远程分支
git branch -dr [remote/branch] # 删除远程分支

4.6 切换分支checkout

git checkout [branch-name] # 切换到指定分支,并更新工作区git checkout - # 切换到上一个分支

4.7 合并分支merge

git merge [branch] # 合并指定分支到当前分支git cherry-pick [commit] # 选择一个commit,合并进当前分支

4.8 标签操作tag

git tag # 列出所有taggit tag [tag] # 新建一个tag在当前commitgit tag [tag] [commit] # 新建一个tag在指定commitgit tag -d [tag] # 删除本地taggit push origin :refs/tags/[tagName] # 删除远程taggit show [tag] # 查看tag信息git push [remote] [tag] # 提交指定taggit push [remote] --tags # 提交所有taggit checkout -b [branch] [tag] # 新建一个分支,指向某个tag

4.9 查看Git信息

git status # 显示有变更的文件git log # 显示当前分支的版本历史git log -5 --pretty --oneline # 显示过去5次提交git shortlog -sn # 显示所有提交过的用户git blame [file] # 显示指定文件是什么人在什么时间修改过git diff # 显示暂存区和工作区的代码差异git diff --cached [file] # 显示暂存区和上一个commit的差异git diff HEAD # 显示工作区与当前分支最新commit之间的差异git diff [first-branch]...[second-branch] # 显示两次提交之间的差异

4.10 同步

git fetch [remote] # 下载远程仓库git pull [remote] [branch]# 取回远程仓库的变化,并与本地分支合并git push [remote] [branch] # 上传本地指定分支到远程仓库git push [remote] --force # 强行推送当前分支到远程仓库,即使有冲突 git push [remote] --all # 推送所有分支到远程仓库

4.11 撤销提交

git reset [file] # 撤销修改暂存区的指定文件,与上一次commit保持一致,但工作区不变git reset --hard # 撤销修改重置暂存区与工作区,与上一次commit保持一致

4.12当前操作暂存

git stash # 暂时将未提交的变化移除,稍后再移入
git stash pop # 取出暂存的工程

4.13 拉取远程到本地分支

git pull origin master:master
git pull <远程主机名> <远程分支名>:<本地分支名>
如拉取远程的master分支到本地wy分支:
git pull origin master:wy
提交 push

官网已经提供了很丰富的资料,此处记录,以便查看。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/405484.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关于检测手机信号强度,wifi信号强度以及检测周围wifi热点的一个小例子

From: http://blog.csdn.net/wanglj0925/article/details/7743182 一.检测手机信号强度 检测手机信号强度需要用到TelephonyManager类 这个类主要提供了一系列用于访问与手机通讯相关的状态和信息的get方法。其中包括手机SIM的状态和信息、电信网络的状态及手机用户的信息。在…

转载:关于爱情、伴侣、承诺、人生、

关于爱情&#xff1a; 不要认为后面还有更好的&#xff0c;因为现在拥有的就是最好的。 不要认为还年轻可以晚些结婚&#xff0c;爱情是不等年龄的。 不要因为距离太远而放弃&#xff0c;爱情可以和你一起坐火车的。 不要因为对方不富裕而放弃&#xff0c;只要不是无能的人&am…

Net4.0的网站在IE10、IE11出现“__doPostBack未定义”的解决办法。

方法一、浏览器设置成兼容模式。 方法二、安装服务器版的.Net40的补丁。http://download.csdn.net/detail/5653325/6642051 方法三、点击VS的工具菜单--》库程序包管理器--》程序包管理器控制台&#xff08;如果没有“库程序包管理器”的菜单&#xff0c;就先点那个“扩展管理器…

数理统计中的卡方分布,t分布和F分布

有很多统计推断是基于正态分布的假设&#xff0c;以标准正态分布变量为基石而构造的三个著名统计量在实际中有广泛的应用&#xff0c;这是因为这三个统计量不仅有明确背景&#xff0c;而且其抽样分布的密度函数有显式表达式&#xff0c;它们被称为统计中的“三大抽样分布”。这…

Bringing up interface eth0: Device eth0 does not seem to be present, delaying initialization

克隆虚拟机后&#xff0c;网卡无法启动&#xff0c;并报如下错误&#xff1a; 解决办法1.修改虚拟机克隆机的HWADDR为ifconfig -a的MAC地址 形如&#xff1a;HWADDR"xx:xx:xx:xx:xx:xx" 2.然后再做以下操作 # rm -rf /etc/udev/rules.d/70-persistent-net.rules # re…

在计算机发展的早期 计算机主要用于,全国网络统考《计算机应用基础》选择题复习...

全国网络统考《计算机应用基础》选择题复习 全国网络统考《计算机应用基础》选择题复习第一章计算机基础知识【例题与解析】、一般认为&#xff0c;世界上第一台电子计算机诞生于()。年年年年【解析一般认为&#xff0c;世界上第一台数字计算机于年在美国宾夕法尼亚大学研制成功…

数理统计中95%置信区间的含义

95%置信区间&#xff0c;意味着如果你用同样的步骤&#xff0c;去选样本&#xff0c;计算置信区间&#xff0c;那么100次这样的独立过程&#xff0c;有95%的概率你计算出来的区间会包含真实参数值&#xff0c;即大概会有95个置信区间会包含真值。而对于某一次计算得到的某一个置…

Linux 程序后台运行与删除

一、查看进程&#xff1a;ps 或 ps -a 二、命令后台运行&#xff1a; sudo ./runmyled.o& 命令后边跟个&, 返回进程id号 三、查看当前的进程&#xff1a; 四、删除进程&#xff1a;sudo kill id1 id2 id3

jquery html 片段,十条jQuery代码片段助力Web开发效率提升

JQuery是继prototype之后又一个优秀的Javascript库。它是轻量级的js库 &#xff0c;它兼容CSS3&#xff0c;还兼容各种浏览器(IE 6.0, FF 1.5, Safari 2.0, Opera 9.0)&#xff0c;jQuery2.0及后续版本将不再支持IE6/7/8浏览器。jQuery使用户能更方便地处理HTML(标准通用标记语…

React开发(255):react项目理解 ant design 注意报错提示

if (res.data.records.length 0 && pageUserIndex > 1) {

华为IoT平台NB编解码插件开发详细教程【上篇】

目录 0、前言 一、环境搭建 1.1 安装JDK 1.2 安装eclipse 1.3 安装Maven 二、Profile说明 三、插件编写 3.1 源文件说明 3.2 修改文件路径&#xff08;包含&#xff09; 3.3 修改pom.xml 3.4 导入工程 3.5 代码实现 3.6 生成jar包 0、前言 本教程分为上、下篇&am…

用MySQL实现微博关注关系的方案分析

关注关系产生的四种关系状态 关注粉丝双向关注(互粉)无关系用词follower表示粉丝 -- 追随者 用词following表示关注 -- 追随 设计的结构必须能满足以下功能&#xff1a; 查询关注列表查询粉丝列表查询双向关注列表判断两个用户的关系查询带关系状态的任一列表第一种方案 用一行…

带你封装一个上传图片组件(ant design+react)

目录 需求实现 实现效果 代码封装 UploadImage组件 备注 BaseUploadImage组件 index.less 样式文件 父组件引用 需求实现 1可以支持上传最多九张图片 2图片支持预览 替换 删除 3支持自定义上传文件大小 格式 未上传提示 实现效果 代码封装 UploadImage组件 * Descri…

计算机面试的时候写过的代码,程序员悲催瞬间:来之不易的美团面试,我尽然挂了(还原真实场景)...

一面1、自我介绍答&#xff1a;自我介绍是面试中唯一的自己主动介绍自己的环节&#xff0c;一定要好好把握好&#xff0c;你数据结构学的号可以手撕一个红黑树你就说我数据结构掌握地很好&#xff0c;反正就是要把自己的优势凸显出来&#xff0c;比如自己对于java的知识较熟悉&…

华为IoT平台NB编解码插件开发详细教程【下篇】

上篇文章介绍了编解码开发汇总的环境搭建、Profile说明和插件编写&#xff0c;本篇教程就插件打包、插件质检和插件签名详解。 目录 四、插件打包 五、插件质检 六、插件签名 七、附件 四、插件打包 1、新建package文件&#xff0c;包含一个“preload”子文件夹&#xff…

【PostGIS】PostgreSQL15+对应PostGIS安装教程及空间数据可视化

一、PostgreSQL15与对应PostGIS安装 PostgreSQL15安装&#xff1a;下载地址PostGIS安装&#xff1a;下载地址&#xff08;选择倒数第二个&#xff09; 1、PostgreSQL安装 下载安装包&#xff1b;开始安装&#xff0c;这里使用默认安装&#xff0c;一直next直到安装完成&…