再备注: Git
就是开发时,用来方便你控制自己写的“山寨QQ”
软件现在是1.0版本
还是2.0版本
,然后还可以查到1.0
干了什么,2.0
相对于1.0
修改了什么,还可以回滚到1.0版本
(觉得我这话还是没法理解的,请往上走去找度娘)
再再备注: 有了Git
,很简单就可以实现——多人同时开发一个项目。
3.0 对,你的感觉没错,Git是需要另外安装的,它是一个软件。
Windows
和linux
安装网上都有很多办法。而且,Windows
系统和linux
系统安装同样的简单粗暴:
Windows:
下载链接:Git最新版本下载官网
(你没看错,这个官网网站名字就叫“Git下载Downloading Git
”)
从上面这个链接你可以从官网上下载到最新的Git
软件
Linux:
打开shell界面,输入:
sudo apt-get install git-core
(Git
和Linux
都是同一个作者,所以其实在Linux
系统上安装反而最简单方便)
具体图文安装教程如下(我知道,有的人的确需要带路党才不会出错,我做的就是这样的事情):
链接:Windows下的git安装教程(其实除了选一下安装目录,也就是一直下一步)
链接:linux下安装git(其实就是一句执行命令的事情)
备注:上面linux
系统安装这个链接,是基于Centos linux
系统环境下,也就是RedHat Enterprise Linux (RHEL)
和Fedora
系列通用的教程。其实常用的linux发行版
一般都会内置好Git
,Ubuntu
系统应该只会更简单,比如去“应用商店”
找一下……
4.0 这时候(或者某个时候……),Android studio
会自动提示(右下角弹出一个小提示框),你似乎可以绑定下Git
?!
链接:AndroidStudio怎样和Git关联
事实上一般Android studio
会很智能的让你把提示点开,然后填入Git
安装目录地址,找到Git.exe
,确认,就搞定了。然后就会出现方便的Git
控制:
2019-02-21_103504.png
5.0 好吧,原始出奇迹,你可以在cmd中输入git --version
2019-02-21_103710.png
可以看到,确确实实是装好了。
然后桌面也会出现Git Bash
图标(快捷方式),点开它:
2019-02-21_103821.png
2019-02-21_103857.png
6.0 新手学习阶段,先学会一个语句:
find . -name ".git" | xargs rm -Rf
2019-02-21_105252.png
这样当你玩脱了的时候,这个命令可以帮助你删掉某个项目中Git
的一切(相当于卸载该项目的Git
),你可以重新给项目安装Git
,再来一次……
7.0 Git使用前,需要做一件事。
给自己弄个身份,这样在提交代码的时候
Git
可以知道是谁在提交代码。命令如下:
git config --global user.name "Tony"git config --global user.email "Tony@email.com"
(当然你可以叫别的,这只是一个示范案例而已。)
8.0 先把ProviderTest项目的代码贴上来:
项目文件目录
2019-02-20_210200.png
activity_main.xml
<?xml version="1.0" encoding="utf-8"?><android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <Button android:id="@+id/add_data" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="添加数据到book" app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintHorizontal_bias="0.20" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent" app:layout_constraintVertical_bias="0.06" /> <Button android:id="@+id/query_data" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="从book中查询数据" app:layout_constraintBottom_toBottomOf="@+id/add_data" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toEndOf="@+id/add_data" app:layout_constraintTop_toTopOf="@+id/add_data" /> <Button android:id="@+id/update_data" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="8dp" android:layout_marginBottom="8dp" android:text="更新数据到book" app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintEnd_toEndOf="@+id/add_data" app:layout_constraintStart_toStartOf="@+id/add_data" app:layout_constraintTop_toBottomOf="@+id/add_data" app:layout_constraintVertical_bias="0.06" /> <Button android:id="@+id/delete_data" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="从book中删除数据" app:layout_constraintBottom_toBottomOf="@+id/update_data" app:layout_constraintEnd_toEndOf="@+id/query_data" app:layout_constraintStart_toStartOf="@+id/query_data" app:layout_constraintTop_toTopOf="@+id/update_data" /></android.support.constraint.ConstraintLayout>
MainActivity.java
package com.example.providertest;import android.content.ContentValues;import android.database.Cursor;import android.net.Uri;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.view.View;import android.widget.Button;import android.widget.Toast;public class MainActivity extends AppCompatActivity { private String newId; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Button addData = (Button) findViewById(R.id.add_data); addData.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { //添加数据 Uri uri = Uri.parse("content://com.example.databasetest.provider/book"); ContentValues values = new ContentValues(); values.put("name", "王之国度"); values.put("author", "张三"); values.put("pages", 1040); values.put("price", 55.55); Uri newUri = getContentResolver().insert(uri, values); newId = newUri.getPathSegments().get(1); } }); Button queryData = (Button) findViewById(R.id.query_data); queryData.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Uri uri = Uri.parse("content://com.example.databasetest.provider/book"); Cursor cursor = getContentResolver().query(uri, null, null, null, null); if (cursor != null) { while (cursor.moveToNext()) { String name = cursor.getString(cursor.getColumnIndex("name")); String author = cursor.getString(cursor.getColumnIndex("author")); int pages = cursor.getInt(cursor.getColumnIndex("pages")); double price = cursor.getDouble(cursor.getColumnIndex("price")); Toast.makeText(MainActivity.this, "name is" + name + ",\n author is" + author + ",\n pages is" + pages + ",\n price is" + price, Toast.LENGTH_SHORT).show(); } cursor.close(); } } }); Button updateData = (Button) findViewById(R.id.update_data); updateData.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { //更新数据 Uri uri = Uri.parse("content://com.example.databasetest.provider/book/" + newId); ContentValues values = new ContentValues(); values.put("name","创世之神"); values.put("pages", 8250); values.put("price", 198.72); getContentResolver().update(uri, values, null, null); } }); Button deleteData = (Button) findViewById(R.id.delete_data); deleteData.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Uri uri = Uri.parse("content://com.example.databasetest.provider/book/" + newId); //删除数据 getContentResolver().delete(uri, null, null); } }); } }
AndroidManifest.xml没有修改,就不贴代码了。
9.0 具体操作如下(可能知识点讲解会相当繁琐,但我以谷歌
的人品发誓,知识点绝对是不重复的):
1.准备工作:
打开Git Bash
,,进入项目的根目录下,然后执行git init
2019-02-21_091907.png
这样准备工作就已经完成了,我们可以继续Git
之旅。2.提交ProviderTest项目代码。
在提交之前我们还有一个问题:是不是所有文件都会加入版本控制当中?
比如说,我们知道Android项目结构
目录下,build
目录下的文件是编译项目时自动生成的,所以这部分文件添加到版本控制之中,没有任何意义,而且还会增加你的数据阅读量。这里,
Git
使用的是排除法,它有一套可配性很强的机制,检查代码仓库目录下是否存在一个名为.gitignore
的文件(记事本就可以打开),它会一行一行去读取里面的内容,把每一行指定的文件
或目录
排除在版本控制之外(注意:.gitignore
指定的文件
或目录
可以使用*
通配符)2019-02-21_111720.png
2019-02-21_111834.png
可以看到,Git
是不管里面这些文件的版本控制的。
在app模块下还有一个.gitignore
文件,这个就简单多了:
2019-02-21_111950.png
2019-02-21_092146.png
由于app模块下基本都是我们自己编写的代码,所以默认只会有其中的build
目录不会被添加到版本控制之中。
但我们可以任意添加,比如说app模块
下所有的测试文件我都只提供给自己用,并不想上传到Git
版本控制中,那么我们可以这样修改app/.gitignore
文件中的内容:
2019-02-21_092122.png
好,理论讲解完毕,提交代码只有两句命令:
先使用add命令将所有文件添加,命令如下:
git add .
然后执行commit命令完成提交,命令如下:
git commit -m "First commit"
执行结果如下:
2019-02-21_092254.png
我们可以查看一下提交记录,命令如下:
git log
执行结果如下:
2019-02-21_113324.png
可以看到,确确实实是提交成功了。
3.查看修改内容
命令如下:
git status
执行结果如下:
2019-02-21_092350.png
可以看到,Git
提示没有任何可提交的文件。
现在我们修改下ProviderTest项目中的代码,修改MainActivity.java
中的代码:
2019-02-21_113726.png
重新输入git status
命令,结果如下:
2019-02-21_092521.png
可以看到,Git
提示我们MainActivity.java
文件已经发生了改变。
查看更改内容命令:
git diff
命令执行结果如下:
查看修改的具体内容
减号代表删除部分,
加号代表添加部分。
如果只想查看MainActivity.java
文件修改的部分:
git dif fapp/src/main/java/com/example/providertest/MainActivity.java
命令执行结果如下:
2019-02-21_092747.png
4.撤销未提交的修改
这可以解决我们有时候代码写的过于草率,以至于原本正常的功能,结果反而被我们改出了问题。
遇到这种问题,我们只要代码未提交,修改的内容可以通过Git命令
撤销。
比如撤销上面价格的修改:
git checkout app/src/main/java/com/example/providertest/MainActivity.java
命令执行结果如下:
2019-02-21_092912.png
我们点开Android Studio,查看MainActivity.java文件:
16102290-729be1adb785b8dc.png
会发现代码已被自动还原成价格45.96。
再运行git status
命令检查一下,结果如下:
2019-02-21_093010.png
可见,撤销不仅真的撤销成功了,而且Git
也认为它已经撤销成功了。
但是如果某个文件已经添加了,那么就无法撤销其修改的内容,比如我们重新把价格改为55.55,然后执行如下命令:
gti add .
再运行git status
命令检查一下,结果如下:
2019-02-21_100411.png
如果我们再执行一遍checkout
命令,会发现Android Studio
里面ProviderTest
项目中MainActivity.java
文件的内容无法被撤销掉:
2019-02-21_1552.png
2019-02-21_120236.png
我们可以取消添加,然后撤销,取消添加命令如下:
git reset HEAD app/src/main/java/com/example/providertest/MainActivity.java
执行结果如下:
2019-02-210552.png
查看Android Studio
里面ProviderTest
项目中MainActivity.java
文件,又回滚到价格45.96。
5.查看提交记录。
上面已经介绍了,我们继续把Android Studio
里面ProviderTest
项目中MainActivity.java
文件中的价格修改为55.55,然后再执行一次提交操作:
git add . git commit -m "Change price"
重新执行git log
,执行结果如下:
2019-02-21_100552.png
2019-02-21_100601.png
当提交记录较多时,如果只想查看其中一条记录,我们可以指定该记录的id,并加上-1
参数表示我们只想看到一行记录,命令如下:
git log c8405ae68eed5e6d7b20fa9a4c84caf09619fd3c -1
执行结果如下:
2019-02-21_100700.png
如果想看这条记录修改了什么内容,可以在命令中加入-p
参数,命令如下:
git log c8405ae68eed5e6d7b20fa9a4c84caf09619fd3c -1 -p
执行结果如下:
2019-02-21_100757.png
作者:我睡醒刚刚
链接:https://www.jianshu.com/p/b7346844ed0c
共同学习,写下你的评论
评论加载中...
作者其他优质文章