git进入项目目录 windows_Git使用教程 Windows使用Git全攻略

在Windows上安装Git

点击Download开始下载,下载完成后双击安装包进行安装,之后一直点击“下一步”就可以完成安装了。

创建代码仓库

首先配置一下身份,这样在提交代码的时候Git就可以知道是谁提交的了。打开Git Bash,输入下面的命令

git config -global user.name "Andy"git config-global user.email "glp664186796@gmail.com"

配置完成后可以用同样的命令查看是否配置成功,将最后的名字和邮箱地址去掉即可。如下图所示:

然后就可以开始创建代码仓库了,仓库(Repository)是用于保存版本管理所需信息的地方,所有本地提交的代码都会被提交到代码仓库中,如果有需要还可以再推送到远程仓库中。

这里给 CoolWeather 项目建立一个代码仓库。先进入 CoolWeather 项目的目录下面,如图:

然后输入命令:

git init

这样即可完成创建代码仓库的操作。

仓库创建完成后,会在 CoolWeather 项目的根目录下生成一个隐藏的.git文件夹,这个文件夹是用来记录本地所有的Git操作的,可以通过”ls -al”命令来查看。如果想要删除本地仓库,删除这个文件夹就行了。

提交本地代码

代码仓库建立完之后就可以提交代码了,使用add和commit两个命令就可以。add用来把想要提交的代码先添加进来,commit用来执行提交操作。比如想添加 build.gradle 文件,可以输入如下命令:

git add build.gradle

这是添加单个文件的方法,如果想添加一个目录,在add后面加上目录名字就可以了。比如要把整个app目录下的所有文件进行添加,可以输入下面的命令:

git add app

不过这样操作有点繁琐,我们可以用下面这个命令一次性把所有文件都添加好:

git add .

所以,我们要想把 CoolWeather 这个项目提交的话,可以输入以下命令:

git add .

git commit-m"First commit"

注意,在commit的命令后面,一定要通过-m参数来加上提交的描述信息,没有描述信息的提交被认为是不合法的。这样所有的代码就已经成功提交了!

忽略文件

我们在进行提交代码操作的时候,一般并不是所有文件都需要加入到版本控制中。比如Android Studio项目结构中build目录下的文件都是编译项目时自动生成的,我们不应该将这部分文件添加到版本控制中,Git提供了一种可配性很强的机制实现这个功能。

Git会检查代码仓库的目录下是否存在一个名为.gitignore的文件,如果存在,就一行行读取这个文件中的内容,并把每一行指定的文件或目录排除在版本控制之外。注意.gitignore中指定的文件或目录是可以用“*”通配符的。

Android Studio在创建项目的时候会自动创建出两个.gitignore文件,一个在根目录下面,一个在app模块下面。我们只需要修改.gitignore文件中的内容,即可让一些文件不被添加到版本控制中。

比如app模块下的所有测试文件都只是给我自己使用的,我并不想把它们添加到版本控制中,那么就可以这样修改app/.gitignore文件中的内容:

/build/src/test/src/androidTest

注:第一行的/build是自带的。

下面再进行提交

git add .

git commit-m"First commit"

这样即可将app模块下的所有测试文件不被添加到版本控制中。

查看修改内容

有时我们写项目写到后面忘记了前面修改什么东西了,我们可以使用Git查看自上次提交后文件修改的内容。

在项目的根目录下输入如下命令:

git status

如果我们刚刚才提交过代码,那么Git会提示目前项目中没有任何可提交的文件。如果我们自上次提交代码已经做过了一些改动,那么Git会提醒哪个文件发生了更改。借助diff命令可以看到所有文件的更改内容:

git diff

如果只想查看MainActivity.java这个文件的更改内容,可以使用如下命令:

git diff app/src/main/java/com/example/coolweather/MainActivity.java

我们就可以看到具体的改动情况。其中,减号代表删除的部分,加号代表添加的部分。

撤销未提交的修改

有时我们写代码过于草率,将正常的功能的代码修改出了问题。不过不用着急,只要代码还没提交,所有修改的内容都是可以撤销的。

比如我们想要撤销对MainActivi.java中内容的修改,我们可以用这个命令:

git checkout app/src/main/java/com/example/coolweather/MainActivity.java

执行这个命令以后,我们对MainActivi.java做的一切修改都会被撤销。不过这种撤销方式只适用于那些还没执行过add命令的文件。如果我们想要对一个已经添加过的文件撤销修改,那么我们要先使用reset命令对其取消添加,然后才可以撤回提交。用法如下:

git reset HEAD app/src/main/java/com/example/coolweather/MainActivity.java

然后再使用checkout命令将修改的内容进行撤销。

查看提交记录

当一个项目开发了几个月之后,我们早就忘了每次提交都修改了哪些内容。我们可以使用log命令查看历史提交信息:

git log

每次提交记录都会显示提交id、提交人、提交日期及提交描述这四个信息。

如果我们只想查看其中一条记录,可以在命令中指定该记录的id,并加上 -1参数,表示我们只想看到一行记录:

git log 1fa380b502a00b82bfc8d84c5ab5e15b8fbf7dac -1

如果想要查看这条提交记录具体修改了什么内容,可以在命令中加入 -p参数:

git log 1fa380b502a00b82bfc8d84c5ab5e15b8fbf7dac -1 -p

分支的用法

分支的主要作用就是在现有代码的基础上开辟一个分叉口,使得代码可以在主干线和分支线上同时进行开发,且相互之间不会影响。

如果想要查看当前的版本库中有哪些分支,可以使用git branch这个命令。如果项目中没有创建过任何分支,那么只会有一个master分支存在,也就是主干线。

建立分支可以用下面的命令:

git branch version1.0

这样就创建了一个名为version1.0的分支,然后再次输入git branch来检查一下:

你会发现master分支的前面有一个“*”号,说明目前我们的代码还是在master分支上的,我们可以用checkout命令将代码切换到别的分支上:

git checkout version1.0

这样我们就可以把代码切换到version1.0这个分支上了。

在某个分支上修改并提交的代码不会影响到其他的分支,如果我们在version1.0分支上修复了一个bug,在master这个分支上这个bug依然存在,我们可以使用merge命令完成合并操作:

git checkout master

git merge version1.0

这样就可以把version1.0分支上修改并提交的内容合并到master分支上了。

在合并分支的时候还有可能出现代码冲突的情况,这时候就需要自己慢慢找到并解决这些冲突了。

当我们不再需要version1.0这个分支的时候,可以用如下命令删除这个分支:

git branch -D version1.0

与远程版本库协作

比如现在有一个远程版本库的Git地址是:https://github.com/example/test.git,那么我们可以使用下面的命令将代码下载到本地:

git clone https://github.com/example/test.git

之后你在这份代码的基础上进行了一些修改和提交,再使用push命令将本地的修改内容同步到远程版本库上:

git push origin master

其中origin部分指定的是远程版本库的Git地址,master部分指定的是同步到哪一个分支上。

对于将远程版本库上的修改同步到本地,Git提供了2种命令来完成此功能,分别是fetch和pull。先来讲讲fetch:

git fetch origin master

执行这个命令后,就会将远程版本库上的代码同步到本地,不过同步下来的代码不会合并到任何分支上去,而是会存放到一个origin/master分支上,这时我们可以通过diff命令来查看远程版本库上到底修改了哪些东西:

git diff origin/master

之后再调用merge命令将origin/master分支上的修改合并到主分支上:

git merge origin/master

而pull命令则是相当于将fetch和merge两个命令放在一起执行了

git pull origin master

将代码托管到GitHub上

注册GitHub账号并登陆,点击Start a project来创建一个版本库。可以对版本库命名,然后选择添加一个Android项目类型的.gitignore文件,并使用Apache License 2.0来作为该项目的开源协议。接着点击Create repository,这个版本库就创建完成了,红框里的就是这个版本库的Git地址。

然后打开Git Bash并切换到CoolWeather的工程目录下,输入下面的命令将远程版本库克隆到本地。

git clone https://github.com/jshguoxin/coolweather.git

现在我们需要将这个目录中的文件全部复制粘贴到上一层目录中,这样就能将整个CoolWeather工程目录添加到版本控制中去了。注意.git是一个隐藏目录,在复制的时候千万不要漏掉。另外,在上一层目录中也有一个.gitignore文件,将其覆盖即可。复制完成后将coolweather目录删除。

接下来应该把CoolWeather项目中现有的文件提交到GitHub上面,输入下面的命令:

git add .

git commit-m "First commit"git push origin master

以上就是关于在Windows上操作Git的所有教程了,欢迎留言讨论!

本文属转载!!!

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

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

相关文章

linux调度程序是根据进程的动态优先级还是静态优先级来调度进程的,LINUX内核面试题...

该链接有每个题详细的答案讲解http://www.docin.com/p-442803876.html 以下答案可能不是很详细。 1) Linux中主要有哪几种内核锁? Linux的同步机制从2.0到2.6以来不断发展完善。从最初的原子操作,到后来的信号量,从大内核锁到今天的自旋锁。这…

android 自定义控件的宽高_巧用Handler获取View控件信息

众所周知,在Android实际开发中,对于某些复杂多变的情况,控件的位置摆放、大小控制并非是xml类型的layout文件完全可以搞定的。此时,我们通常会使用Java代码来通过动态计算,将指定的控件摆放在相应的位置,并…

ascii码01100001_ASCII码跟数字

小小乌龟把头藏: - - 我竟无言以对!举个例子嘛,本质是这样,你还是把C语言基础什么的看几遍吧。给你摘录一点书上的,估计你更能看懂:计算机是以二进制的形式来存储数据的,它只认识0和1两个数字,我…

深度linux缺点,原来国产深度系统有这些“缺陷”,难怪只有少数人在使用!

相信大家或多或少都听说过USO统一操作系统,一款可以支持多款国产芯片的国产操作系统。该系统从公布直至到现在,它一直保持着非常高的关注度。但是,有些用户认为该系统只不是Deepin换了壳而已。从系统界面来看,UOS和Deepin的确非常…

如何ping端口_干货 | 如何正确处理常见的8大网络故障

网络故障是最容易出现的,也是比较难解决的问题,尤其是经常跟电脑及交换机打交道的朋友。今天就和大家来说说日常工作中,常见的网络故障详细分析及解决方法。交换机刚加电时网络无法通信【故障现象】交换机刚刚开启的时候无法连接至其他网络&a…

前端vue显示柱状图_Vue—Echarts 柱状图

使用Vue做后台管理系统的时候避免不了使用Echarts来展示对应的数据,下面是使用Echarts柱状图来展示对应数据的实例。ee05abaf9633184a9c012631b642d970.png使用npm安装Echartsnpm install echarts --save在man.js中引入对应的echartsimport ECharts from vue-echart…

c语言程序设计第2章,C语言程序设计第2章 结构化程序设计与算法.ppt

C语言程序设计第2章 结构化程序设计与算法.ppt现在人们公认的具有“良好风格”的程序设计方法之一是所谓的“结构化程序设计方法”。其核心是规定了算法的三种基本结构顺序结构、选择结构和循环结构。按照结构化程序设计的观点,任何算法功能都可以通过三种基本程序结…

python读取word指定内容_python读取word 中指定位置的表格及表格数据

1.Word文档如下:2.代码 # -*- coding: UTF-8 -*- from docx import Document def readSpecTable(filename, specText): document Document(filename) paragraphs document.paragraphs allTables document.tables specText specText.encode(utf-8).decode(utf-8)…

xml建模包括以下_为什么要进行建模仿真?

没有“模型”作为基础的话,很多当今的前沿概念将无法真正落地!今天,数字孪生、人工智能、工业互联网、边缘计算这些概念在整个产业里非常的火热,但是,要知道,如果这些概念没有“模型”作为基础的话&#xf…

中兴没有云服务器_中国移动携手中兴通讯推进5G网络云建设

11月23日消息今年8月,中国移动通信集团公司党组成员、副总裁李慧镝在“中国信息化百人会2020年峰会”上表示,中国移动正大力推进网络云化部署,实现云网融合,NFV网络云服务器规模达6万台。2020北京国际信息通信展期间,中…

c语言乘法表只有结果,要求输出结果显示相乘的两数及乘积怎么做?

1。#includevoid main(){int i,j;printf("* ");for(i1;i10)printf("%d ",i*j);else printf("%d ",i*j);}printf("\n");}}2。#includevoid main(){int k,m,n,days;printf("请输入树的高度Kcm:");scanf("%d",&k…

差异基因 p log2foldchange_拟南芥的基因ID批量转换?差异基因,GO/KEGG数据库注释(转录组直接送你全套流程)...

新手遇到的问题都是类似的,比如批量ID转换虽然我写过大量的教程:ID转换大全 不过都需要R基础,因为是大批量转换啊!但热心肠的植物生物信息学教学大佬还是友善的给出了解决方案我也狗尾续貂制作了一个网页工具教程:简…

c语言实现顺序表源程序,C语言实现静态顺序表的实例详解

C语言实现静态顺序表的实例详解线性表定义一张顺序表也就是在内存中开辟一段连续的存储空间,并给它一个名字进行标识。只有定义了一个顺序表,才能利用该顺序表存放数据元素,也才能对该顺序表进行各种操作。接下来看看静态的顺序表&#xff0c…

证明最小码距与纠检错图像_最小码距和检错纠错能力关系

最小码距和检错纠错能力关系一、码距?码距就是两个码字C1与C2之间不同的比特数。如:1100与1010的码距为2;1111与0000的码距为4。一个编码系统的码距就是整个编码系统中任意(所有)两个码字的最小距离。若一个编码系统有四种编码分别为:0000&am…

mongoose 批量修改字段_WordPress图片路径批量替换方法

不少数站长在使用WordPress博客或者搬家时,需要把WordPress文章中的图片路径进行替换来解决图片不显示的问题。总结一下WP图片路径批量替换的过程,方便有此类需求的站长们学习。什么情况下批量替换图片路径1、更换了网站域名有许多网站建设初期都随便选择…

c语言 静态变量 初始化,c – 静态变量初始化两次

考虑到我在编译单元中有一个静态变量,最后在静态库libA中.然后我有另一个编译单元访问这个变量,最终在一个共享库libB.so(所以libA必须链接到libB).最后,我有一个主要功能也直接从A访问静态变量,并具有对libB的依赖(所以我链接到libA和libB).我然后观察,静态变量被初始化了两次…

ebs 供应商地点信息_供应商,地址,业务实体,地点关联银行账户

在此记录一下自己学习过程。新手,请多多指教,谢谢。最近客户有需求,找出供应商对应的银行信息,查看了下网上帖子,发现都是从供应商及供应商地点层发起,去查找对应的银行信息,但是,供…

c语言递归函数检测回文,递归法判断回文字符串,急用

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼/*--------用线性表存储字符串,结合堆栈判断回文(关键判断个数为奇或偶,奇跳过中间数据)---------*/#include #include #define ok 1;#define error 0;typedef char elemtype;typedef struct lnode{lnode *n…

python vector_50行Python代码实现经典游戏,不仅是划水神器,更是学习利器!

Free Python Games非常适合学生,它不仅具有高度的组织性和灵活性,而且能够激发人们探索和理解能力。--Terri FurtonFree Python Games在轻松的环境中把游戏和学习结合在一起,从而减轻了编程过程中的压力。--Brett Bymaster...贪吃蛇、迷宫、吃…

r roc函数_画ROC曲线的R包总结

原标题:画ROC曲线的R包总结作者: Joseph Rickert原文链接:https://rviews.rstudio.com/2019/03/01/some-r-packages-for-roc-curves/在这篇文章中,我将描述如何在CRAN中搜索绘制ROC曲线的包,并强调六个有用的包。虽然一…