【Android】29.0 Git版本的使用和GitHub上传个人项目

1.0 安装Git

百度,进入Git官网下载最新版,安装,选好安装位置后,一路下一步。

2.0 创建代码仓库

虽然在windows上安装的Git是可以在图形界面上进行操作的。并且Android Studio也支持以图形化的形式操作Git。但是Git的各种命令才是应该掌握的核心技能,不管在哪个操作系统中使用命令来操作Git肯定是通用的。图形化的操作应该是掌握命令用法的前提下,进一步提升自己的工作效率。

2.1 通过命令使用Git

如果你使用的是Linux系统,先打开shell界面,如果使用的是windows系统,从开始菜单中找到Git Bash并打开。


image.png

首先配置一下自己的身份,这样可以在提交代码的时候Git就可以知道是谁提交的,命令如下所示:

git config --global user.name "edpeng"
git config --global user.email "edpeng@gmail.com"
image.png

image.png

配置完成后可以使用同样的命令来查看是否配置成功,只需要将最后的名字和邮箱地址去掉即可。


image.png
2.2 创建代码仓库

仓库(Repository)是用来保存版本管理所需信息的地方。所有本地提交的代码都会被提交到代码仓库中,如果有需要还可以再推送到远程仓库中。
下面尝试给PortableAnti_theft项目建立一个代码仓库。
先进入到PortableAnti_theft项目的目录下面,注意路径是正斜杠。

cd G:
cd workspace/Android/PortableAnti_theft/
image.png

image.png

在接下来的操作之前,需要设置两个.gitignore文件
一个是项目下的.gitignore文件

*.iml
.gradle
/local.properties
/.idea/caches
/.idea/libraries
/.idea/modules.xml
/.idea/workspace.xml
/.idea/navEditor.xml
/.idea/assetWizardSettings.xml
.DS_Store
/build
/captures
.externalNativeBuild

一个是app目录下的.gitignore文件

/build

凡是出现的目录或文件,表示不进行版本控制。

然后输入如下指令,只需要一行命令就可以完成创建代码仓库的操作。

git init
image.png

仓库创建完后会在PortableAnti_theft项目的根目录下生成一个隐藏的.git文件夹,这个文件夹是用来记录本地所有的git操作的,可以通过ls -al命令来查看一下,如下所示。


image.png

如果要删除本地仓库,只需要删除这个文件夹就行了。

3.0 提交本地代码

代码仓库建立完之后就可以提交代码了,其实提交代码的方法也非常简单,只需要使用add和commit命令就可以了。

add 把想要提交的代码先添加进来。
commit 真正去执行提交操作。

git add build.gradle
git add app

但是,如上方法进行添加有些复杂,只需要在add的后面添加一个点,就表示添加所有的文件了,命令如下所示。

git add .
image.png

现在项目下的所有文件都已经添加好了,输入如下命令提交。

git commit -m "First commit"
image.png

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

4.0 查看修改内容

查看文件修改情况的方法非常简单,在项目的根目录下输入命令:

git status
image.png

这时候提示没有任何可提交的文件,因为我们刚刚提交过。
如何查看更改后的内容?

git diff
git diff app/src/main/java/com/example/portableanti_theft/Activity/MainActivity.java
5.0 撤回未提交的修改
git checkout app/src/main/java/com/example/portableanti_theft/Activity/MainActivity.java
6.0 查看历史提交信息
git log
image.png

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

git log 5e78e6b0dd69e2d4ca8750db46b4d23d5af358a8 -1

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

git log 5e78e6b0dd69e2d4ca8750db46b4d23d5af358a8 -1 -p
image.png

其中减号(红色)代表删除的部分,加号(绿色)代表添加的部分(蓝色代表该版本内没有变动的)。


image.png
7.0 分支的用法

开发中的版本迭代:


image.png
7.1 查看当前版本库中有哪些分支
git branch
image.png

master: 主干线
AndroidX:自己之前创建的分支

其中我们的AndroidX最左边有个“*”号,表示我们的代码在AndroidX分支上

7.1 创建分支
git branch version1.0

这样就创建了一个名为 version1.0的分支

7.2 切换分支
git checkout master
image.png
7.2 合并分支
git checkout master
git merge version 1.0
7.2 删除分支
git branch -D version1.0



8.0 与远程版本协作
8.1下载到本地

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

git clone http://github.com/example/test.git
8.2本地同步远程版本库

借助push命令将本地内容同步到远程版本库:

git push origin master

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


image.png

中间会弹出登录窗口,输入账号密码,即可完成上传。


image.png

登录Github,进入该项目主页:
image.png
8.3 远程同步本地

将远程版本库上的修改同步到本地,Git提供两种命令来完成此功能,分别是fetch和pull,fetch的语法规则和push是差不多的:

git fetch origin master

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

git diff origin/master

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

git merge origin/master

而pull命令就相当于将fetch和merge这两个命令放在一块执行,可以从远程版本库上获得的最新的代码并合并到本地:

git pull origin master
9.0 将代码托管到GitHub上
9.1 新建GitHub项目仓库

首先 我们本地有一个项目,GitHub也有一个项目仓库。我的采用的是添加一个Android项目类型的.gitignore文件,并使用Apache License 2.0 开源协议。

输入

git clone https://github.com/bobokaka/PortableAnti_theft-APP

把远程版本库克隆到本地。

9.1 复制合并

将下载下来的文件复制到上一层目录中,覆盖即可。


image.png

然后删除PortableAnti_theft-APP目录。

9.3 提交项目

先将所用文件添加到版本控制中“”

git add .

在本地执行提交操作。

git commit -m "First GitHub commit"

最后将提交的内容同步到远程版本库,也就是GitHub上面:

git push https://github.com/bobokaka/PortableAnti_theft-APP AndroidX

其中的AndroidX是我自己自命名的版本分支的名称。


image.png

image.png

登录GitHub网站,可以看到提交的文件已经存在了。


image.png
10.0 其他命令

git 查看、切换用户
查看命令:
查看用户名:

git config user.name

查看用户邮箱:

git config user.email

修改命令:
修改用户名:

git config --global user.name "Your_username"

修改用户邮箱:

git config --global user.email "Your_email"

注:user.name或者user.email后需有一个空格,再写你的用户名或者用户邮箱

11.0 一些bug的处理
11.1 切换GitHub账户或者GitLab账户

之前没有登陆过的会自动弹出窗体让你输入账号密码,可是换别人的账号登录,就会下载不下来。


image.png

百度的解决方案都是设置什么SSH key,扯淡,主要是修改自己的数据凭据:


image.png

修改保存,即可切换。

11.2 拉取指定分支代码解决方案:

以拉取develop分支的代码为例, 要拉取其余分支代码类似操作
使用git命令拉取

命令:git clone -b develop XXX 

其中develop就是分支的名称

11.3 回滚版本

先查看保存记录

git log -3

只查看前3条。

git reset --hard e377f60e28c8b84158

强行提交

git push -f origin master
11.4 删除分支

1、查看所有分支

git branch -a

2、查看当前所在分支

git branch

3、删除本地的bug_xzx分支

git branch -d bug_xzx

4、删除远程的bug_xzx分支

git push origin --delete bug_xzx

5、Git中的.gitignore文件配置了之后,不生效问题

解决方法

git rm -r --cached .

git add .

git commit -m '代码提交'

git push origin
 

git rm -r --cached:保留本地文件,删除staging area中的文件
git add 本地文件加入到staging area中
提交
push
6.强行合并分支(demo默认在master分支上)

 git merge --strategy-option=theirs dev_pre --allow-unrelated-histories

将dev_pre 强行覆盖合并master分支

--strategy-option=ours  反之

报错:

fatal: unable to access 'https://git.gwi.com.cn:9103/customization/ningbocb/kiosk-cli-2nd.git/': SSL certificate problem: self signed certificate

解决:

git config --global http.sslVerify false

END

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342