Git基本提交操作、stash找回、git忽略文件

git 基本操作流程

git status 查看本次的修改、新建、删除等信息(new file:新建文件,modified:修改文件,deleted: 删除的文件)

git pull 拉取代码;

git add . 添加所有即将提交的文件,

git commit -'提交的日志'   提交到本地,

git push   提交到git服务器;

git 另一种提交方式,

git commit -a -m '提交的日志'     添加所有即将提交的文件并提交到本地  ,

git commit -a -m 相当于git add . 和 git commi -'' 命令的集合,当你使用git commit -a -m ''命令时,就会执行上述两个操作;


git 暂存

使用暂存的好处是,提交时不会产生类似(Merge branch 'prd_v1.5' of http://**.*.***.***/bb_ios/bbch**** into prd_v1.5)的日志,且安全可靠,会尽量避免将错误提交到服务器上面。

git stash暂存(存储在本地,并将项目本次操作还原)

git stash pop 使用上一次暂存,并将这个暂存删除,使用该命令后,如果有冲突,终端会显示,如果有冲突需要先解决冲突(这就避免了冲突提交服务器,将冲突留在本地,然后解决)

git stash list 查看所有的暂存

git stash clear 清空所有的暂存

git stash drop [-q|--quiet] [<stash>] 删除某一个暂存,在中括号里面放置需要删除的暂存ID

git stash apply 使用某个暂存,但是不会删除这个暂存


暂存不小心清空,结果里面有需要的代码,也是有找回方法的

git fsck --lost-found 命令找出刚才删除的分支里面的提交对象。

然后使用 git show 命令查看是否正确,如果正确使用git merge命令找回

举个栗子🌰:

git fsck --lost-found 

终端显示

Checking object directories: 100% (256/256), done.

Checking objects: 100% (109977/109977), done.

dangling commit bb01f8dfaa14ea7960d294304c61c4b401eaf2c6

dangling commit 0203281d5dee10835022ff6cfdcda5050a372762

git show  bb01f8dfaa14ea7960d294304c61c4b401eaf2c6

结果查看图1

记录中会描述日期和摘要,日期是你git stash的日期,摘要会记录你是在哪一条commit 上进行git stash操作的,找到后将执行 git merge bb01f8dfaa14ea7960d294304c61c4b401eaf2c6

图1(git show  bb01f8dfaa14ea7960d294304c61c4b401eaf2c6 命令后的展示)

git 创建本地分支并推送到服务器

创建并切换到分支branchName

git checkout -b branchName

推送本地的branchName(冒号前面的)分支到远程origin的branchName(冒号后面的)分支(没有会自动创建)

git push origin branchName:branchName 

在这样的命令下,如果你本地有代码,会自动切换到新的分支上,所以不必担心,你修改很多之后,从新创建分支会出现正常切换分支因为有未提交的代码而创建不成功的情况

发现问题,如果命令行提示git branch --set-upstream dev origin/branchName则需在终端输入git push -u origin branchName


生成git忽略文件.gitignore文件,使用终端进入到你要生成.gitignore的目录,使用命令` touch .gitignore`,就会生成。

下面我们看看常用的规则:

1)/mtk/ 过滤整个文件夹

2)*.zip过滤所有.zip文件

3)/mtk/do.c 过滤某个具体文件

这样文件或者文件夹就被过滤了,当然本地库中还有,只是push的时候不会上传。

.gitignore还可以指定要将哪些文件添加到版本管理中:

1)!*.zip

2)!/mtk/one.txt


如果你将文件加入到了.gitignore文件里面,但是没有说生效,呵呵请使用以下命令

git rm --cached `git ls-files -i --exclude-from=.gitignore` 

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容