赞
踩
[user] email = xxx(邮箱如:foxleezh@gmail.com) name = xxx(名字如:foxleezh) [alias] st = status ci = commit br = branch co = checkout glog = log --pretty=oneline pus = push pul = !git pull --rebase && git submodule update --init --recursive lg = log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit [merge] tool = vim [core] packedGitLimit = 512m packedGitWindowSize = 512m [pack] deltaCacheSize = 2047m packSizeLimit = 2047m windowMemory = 2047m
ssh-keygen -t rsa
# OSX *.DS_Store # Gradle files build/ build_out/ obj/ .gradle/ */build/ captures/ gradle/ # IDEA *.iml .idea/.name .idea/encodings.xml .idea/inspectionProfiles/Project_Default.xml .idea/inspectionProfiles/profiles_settings.xml .idea/misc.xml .idea/modules.xml .idea/scopes/scope_settings.xml .idea/vcs.xml .idea/workspace.xml .idea/libraries .idea/runConfigurations.xml .idea/compiler.xml .idea/copyright/profiles_settings.xml .idea/gradle.xml .idea/ # Built application files *.ap_ # Files for the Dalvik VM *.dex # Java class files *.class # Local configuration file (sdk path, etc) local.properties # Log Files *.log # Special gradle.properties
/*
!.gitignore
!README.md
git init
git st
红色表示已修改未保存到缓存区,绿色表示已保存到缓存区
Git有三个状态,一是修改未保存到缓存,二是保存到缓存,三是提交到版本库
我们可以对比着word文档来学习,状态一就相当于你在word中修改了一些东西,但是没有按ctrl+s键保存起来,状态二就是你修改了东西后按了ctrl+s,暂时存起来了,状态三就是点击了另存为,将它另外存放起来了
git add 文件路径(添加单个文件到缓存)
一开始修改了homepage和loading两个文件,git st后显示红色
使用git add后,将homepage加入到缓存区
git st后,发现homepage变为绿色
git add -u(添加所有修改到缓存)
一开始修改了homepage和loading两个文件,git st后显示红色
使用git add -u后,将homepage和loading一起加入到缓存区
git st后,发现homepage和loading变为绿色
git add . (添加所有文件到缓存,包括新建的文件)
此用法与git add -u类似,区别在于,git add -u只能将修改的文件加入缓存,如果该文件是新建的,要使用git add ., 这个“.”符号表示所有
git reset 文件路径(撤销单个文件)
首先git st后发现,有两个已经加入到缓存区的homepage和loading文件
使用git reset homepage后,将homepage文件撤销
git st后发现,homepage变为红色
git reset(撤销所有缓存区的文件)
首先git st后发现,有两个已经加入到缓存区的homepage和loading文件
使用git reset后,将所有文件撤销
git st后发现,homepage和loading都变为红色
git co 文件路径(撤销单个文件的修改)
首先使用git st,发现有homepage和loading两个文件被修改
使用git co homepage,撤销homepage的修改
git st后发现homepage文件不见了,查看原代码,代码中的修改也没有了
git reset --hard (撤销所有文件的修改)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xR4aAFv4-1608797931265)(http://upload-images.jianshu.io/upload_images/3387045-872f5f8d5060bd31.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)]
首先使用git st,发现有homepage和loading两个文件被修改
使用git reset --hard,撤销所有的修改
git st后发现homepage和loading文件不见了,显示nothing to commit,working directory clean, 这表示当前没有任何的修改
git diff 文件路径(查看单个文件修改)
首先使用git st,有两个文件Homepage,loading被修改
使用git diff homepage,可以看到哪些被修改了,按箭头上下可以翻动,”-”号表示删除(红色显示),”+”号表示添加(红色显示)
查看完成后输入q,即可退出查看
要查看所有修改直接用git diff
git diff --cached (查看处于缓存区的修改)
首先使用git st,有两个文件Homepage,loading被加入到缓存区
使用git diff homepage,可以看到哪些被修改了,按箭头上下可以翻动,”-”号表示删除(红色显示),”+”号表示添加(红色显示)
查看完成后输入q,即可退出查看
要查看所有修改直接用git diff --cached
git ci -m “我修改了什么”
首先git st,发现有两个文件homepage和loading加入到缓存区
使用git ci -m “注释”,将缓存区的内容提交到版本库,这里注释是随便写的,用于提示该commit修改了一些什么内容
git st后发现,缓存区中的内容不见了,这是因为已经提交到版本库中了
git log
git log后发现有两个提交,“我修改了什么”是刚刚提交的commit,下面来分析下:
commit ac76744b1843665d0c6cf1add7cf758bc824c89a (这行是一个md5值,用来唯一标识commit的)
Author: foxleezh foxleezh@gmail.com (这行是说明该commit是谁提交的)
Date: Fri Jul 10 10:02:16 2015 +0800 (提交的时间)
我修改了什么 (之前我们写的注释)
git show commit号
git show ac76744b, 这个ac76744b就是之前git log时对应的md5值,可以只取前6位
查看完成用q退出
我们回顾一下已讲的内容,一般来说使用流程都是
这里我们修改了loading中的内容,然后git add -u 加入到缓存区,因为我们只是修改了很少的内容,不需要重新提交commit,所以使用git ci --amend追加到之前的commit,这时会让我们修改注释内容
这是一个vim的编辑器,之前linux中有讲,按i进入编辑模式,箭头移动光标就可以修改注释,修改好后,按ESC进入一般模式,按:进入命令模式,输入wq,保存退出
git log后发现没有新建commit,只是追加到了之前的commit
我们在使用的过程中可能要回到某一个提交,这时可以使用git reset命令,这个命令可以带参数,–mixed(回到修改未保存状态),–soft(回到缓存区状态),–hard(删除所有修改),默认是–mixed
先讲讲–hard,这个好理解,就是把这个commit之后的所有修改都删除
这里有四个commit
我们先使用git reset --hard ,将“我修改了名字”之后的所有修改的删除
git st后发现,没有任何修改
git log后,已经回到”我修改了名字”的commit
下面我们试试git reset --mixed或者git reset
git log我们会发现–mixed和–hard都回到了“我修改了名字”的版本,区别在于git st后–mixed将“测试reset1”和“测试reset2”中修改的内容保留下来了,这样好处在于,我们有时回到某一个commit不是要删除所有的修改,而是只想改变某一些东西,这时我们把需要改的地方改掉后,再重新提交一个commit,这样会方便很多
最后我们试试git reset --soft
这个跟git reset --mixed差不多,只是它是把之后的修改放入了缓存区
之前我们的操作都是同一个分支上的操作,现在我们引入分支的概念
git br
git默认都会有一个分支叫master,这个分支叫主分支,一般来说我们提交代码的时候是用这个分支来提交,但是实质上它跟普通的分支没有什么区别
为什么我们要引入分支,svn也有分支的概念,但是基本是在服务器端,我们本地基本是在一个分支上修改内容的,然后commit,有时我们改一个东西A可能需要很长时间,当还没有改完却突然要修改另外一个东西B,而且A因为没有改完不能合并到版本库,这时svn就有点乏力了,我们可能要把之前没改完的东西A删除掉,然后再来改接下来的B。
git因为是分布式的,不管是服务器端还是本地,都可以存在很多分支,这样就方便我们利用分支很好地管理代码,当我们修改任务A的时候,我们可以在分支A上修改,分支A在master的基础上新建而来,当我们还没有处理完A就要处理B时,我们可以新建另一个分支B,也是在master的基础上新建而来,这样当我们处理完B,提交后,可以回到A,继续我们之前的开发,当我们开发完A,要提交的时候,我们把B的内容整合进来,这个涉及到分支合并,我们之后再讲
git co -b TEST //新建名为TEST的分支,当前的分支会以绿色显示
当我们新建分支时,是从当前分支的基础上新建的,新建的分支保留了当前分支所有的修改,所以新建分支相当于对当前分支的一份拷贝,而不是一个空的分支
git co master //切换到master分支
git br -D TEST //D大写,表示强制删除
这里有三个分支,分别是master,TESTA,TESTB
主分支master有两个提交
git co TESTA切换到TESTA,上面有三个提交,在master基础上多了一个“测试A”的提交
git co TESTB切换到TESTB,上面有三个提交,在master基础上多了一个“修改B”的提交
现在我们需要把A和B合并到一起
首先切换到TESTA分支,然后使用git rebase TESTB命令,将TESTB合并到TESTA前面
一般来说,如果两个分支没有冲突的话,合并就完成了,像上图有冲突就需要解决冲突
git st后发现,TESTA和TESTB都修改了loading文件
git diff loading后,查看具体的冲突内容,git用特殊的符号标记冲突,<<<<<< HEAD到=之前是你要合并的分支对当前文件的修改,因为现在我是要把TESTB合并到TESTA,所以HEAD就代表TESTB的修改,也就是“我是用来追加的B”是TESTB的修改,然后与>>>>>>之前的内容是TESTA的修改,也就是“我是用来追加的A”这句话
现在我们要做的就是确认好是保留A的内容,还是保留B的内容,还是A和B的内容都保留,我们修改可以用linux的vim工具来修改,也可以直接在Android studio或者xcode中修改,修改时先将<<<<<,======这些特殊标记符号去掉,然后再进行修改
修改完成后,git add -u 将修改的内容加入到缓存区
然后git rebase --continue,继续rebase操作
如果要放弃合并,使用git rebase --abort
合并完成后git log,我们可以看到,TESTB的修改“修改B”已经合并进TESTA了,这时TESTA分支中就包含了A和B的修改
ssh-keygen -t rsa
查看id_rsa.pub文件,将密钥拷贝到服务器密钥库
git clone 服务器仓库地址
一般来说是新建一个空目录,然后去克隆服务器的git仓库
1.新建本地仓库
git init
2.添加远程仓库地址
git remote add origin ssh://****@****:29418/foxleezh/test.git
3.提交远程仓库
git push origin master
4.切换到远程分支
git br -r 查看远程分支
git co 切换到某一个远程分支
5.删除远程分支
git push origin :branch
6.拉取服务器分支并切换到临时分支
git fetch origin branchname && git co FETCH_HEAD
如:
git fetch origin GIT && git co FETCH_HEAD
7.拉取服务器分支并合并到master
git pull
pull命令相当于fetch命令加上merge命令,将服务器master分支的内容拉下来并合并到本地master
git pull --rebase
以rebase形式拉取,相当于fetch命令加上rebase命令
如果是pull其他分支,加上分支名
git pull origin branchA
8.向服务器提交分支
git push
如果是push其他分支,加上分支名
git pull origin branchA
9.常见错误
git config http.postBuffer 524288000
Host www.xxx.com(改成服务器地址)
HostkeyAlgorithms ssh-dss
1.新建父项目、子项目并上传服务器
2.克隆父项目、子项目到不同目录
git clone ssh://<username>@<hostname>:29418/project-1.git
git clone ssh://<username>@<hostname>:29418/lib1.git
git clone ssh://<username>@<hostname>:29418/lib2.git
3.将子项目变为父项目的子模组
git submodule add ssh://<username>@<hostname>:29418/lib1.git libs/lib1(这里目录可以自由更改)
git submodule add ssh://<username>@<hostname>:29418/lib2.git libs/lib2
4.将父项目修改的修改提交服务器
git add -u
git push
至此,子模组新建完成
1.进入子模组目录提交并上传
git add -u
git push
2.进入父项目提交并上传
git add -u
git push
1.克隆父项目
git clone --recursive ssh://<username>@<hostname>:29418/project-1.git
2.切换子项目分支
到子目录下(此时分支处于游离状态)
git co -b newBranch
1.在父目录下更新
git pull
git submodule update
2.切换子项目分支
此时分支处于游离状态
git co -b newBranch
1.根据路径删除子模块的记录
$ git rm --cached [path]
2.编辑“.gitmodules”文件,将子模块的相关配置节点删除掉
清理子模块配置
3.编辑“ .git/config”文件,将子模块的相关配置节点删除掉
清理子模块配置
4.手动删除子模块残留的目录
清理脏文件
一、自己有修改子模组的内容
1.cd到子模组下面,git ci提交代码
2.git push提交子模组到子模组服务器
3.cd到主项目下面,这时会有红色提示如:
modified: CoreChart (new commits)
4.git add ,git ci提交指针到主项目
5.git push提交子模组指针到服务器
二、自己没有修改子模组的内容,只是从服务器上更新
1.git pul 拉代码
正常情况只需要这一步就行
但是如果拉的过程中代码有冲突,会进入rebase的过程
这个时候切忌不要将CoreChart (new commits)这种子模组的东西add -u或者add .
只add冲突的代码,不要add子模组的指针
冲突解决完后,git st如果发现有变红的子模组,git submodule update
如果git submodule update后还是红的,说明修改的人子模组没有提交,请通知其提交
如果说自己对rebase后的指针没有底,不知道对还是不对,
可以cd到对应子模组看看指针是否与子模组服务器(注意不是主项目服务器)最新的一致,
如果一致就是对的,如果不对,git co master,git pul最新子模组代码
git reflog
开发流程(以master为例)
有关git rebase的常识
一些Linux常用命令
tab 补全命令
ctrl+c 停止执行
pwd 打印当前目录
cd 进入某个目录
cd /home/develop 进入绝对路径
cd eclipse 进入相对路径
cd …/ 返回上一级目录
touch [file name]打开或创建一个文件
mkdir -p [dir name] 创建一个目录 -p为强制创建
rm -r [file name/dir name] 删除一个文件或目录
ls -al 列出所有文件(包括隐藏文件)的详细信息
-d 只列出该目录的信息
cp -rd [目标文件] [目的文件] 复制文件
-r是允许目录cp
-d是在拷贝软连接时只拷贝软连接,如果不加则会把原文件一起拷过去
cp -rd test.txt dir/test.txt
mv -i [目标文件] [目的文件] 移动文件
-i是询问是否覆盖同名文件,如果[目标文件][目的文件]相同,那就是重命名
find [dn] [参数]
如:find $HOME -name ‘foxlee’ -o -type f -o -size +20M
-atime +n :访问或执行时间大于n天的文件
-ctime +n :写入、更改inode属性(例如更改所有者、权限或者连接)时间大于n天的文件
-mtime +n :写入时间大于n天的文件
文件的 Access time,atime 是在读取文件或者执行文件时更改的。
文件的 Modified time,mtime 是在写入文件时随文件内容的更改而更改的。
文件的 Create time,ctime 是在写入文件、更改所有者、权限或链接设置时随 Inode 的内容更改而更改的。
因此,更改文件的内容即会更改 mtime 和 ctime,
但是文件的 ctime 可能会在 mtime
未发生任何变化时更改,例如,更改了文件的权限,但是文件内容没有变化。
这里讲一下ls中显示的时间
ls -lc filename 列出文件的 ctime
ls -lu filename 列出文件的 atime
ls -l filename 列出文件的 mtime
继续讲find的参数
-name ‘filename’ 直接查找该文件名的文件(注意加引号)
-type type :通过文件类型查找 type 包含了 f, b, c, d, l, s 等等
d 表示该文件为目录;
f 表示该文件为普通文件;
b 表示该文件为块设备文件,比如磁盘分区
l 表示该文件为连接文件(linux file),上边提到的软连接即为该类型;
c 表示该文件为串行端口设备,例如键盘、鼠标。
s 表示该文件为套接字文件(socket),用于进程间通信。
vim [fn] 编辑文件 有三种模式(一般模式,编辑模式,命令模式),可以自由切换
一般模式下移动光标(esc回到一般模式)
箭头上下左右
一般模式下查找与替换
/word 向光标之后寻找一个字符串名为word的字符串,当找到第一个word后,按”n”继续搜后一个,"N"前一个
一般模式下删除、复制粘贴
dd 删除光标所在的那一行
yy 复制光标所在的那行
p,P p复制的数据从光标下一行粘贴,P则从光标上一行粘贴
u 还原过去的操作
进入编辑模式(按i进入)
i 在当前字符前插入字符
命令模式(按:进入)
:q! 不管编辑或未编辑都不保存退出
:wq 保存,退出
:e! 将文档还原成最原始状态
:set nu 在每行的行首显示行号
:set nonu 取消行号
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。