前言:记得在想学习git的时候,一直停留在思想的层面,总没有弄清楚它的运行机制,经常与github混淆,还好找到了一个好的教程,带我领略了git的风采

(一)git的优点

  git的优点:版本控制在本地不需要连网也可以完成对自己文件版本的控制,并且支持分支等等的功能也大大增强了这个git的功能

(二)git的前骤与解疑

  1.git与github有什么关系

  首先git是一个版本控制的软件,github是一个版本控制的大仓库(所有用户都可以往这个仓库里提交代码)

  2.github仓库里面想要贡献代码

  github仓库里面要贡献代码,提交了代码后需要作者同意了,才可以对其源码进行修改的和贡献

  3.git怎么样能够协同

  git在开发中协同时候要以一个一个仓库中添加每个小组成员私钥这样就可以实现协同的开发

  4.使用git需要配置相关参数才可以顺利拉取和上传本地文件

  查看当前用户: git config --list  可以查看当前用户的信息

  git config --global user.name "用户名"

  git config --global user.email "有效的邮箱"

  5.git工作区图解

  

(三)git的使用方法

  1.把文件夹变成仓库

  git init

  2.把修改的文件提交到本地仓库

  查看暂存区状态(git status) ->  把生产区文件到暂存区(git add .)/(git add 文件名)  ->把暂存区文件提交到版本库(git commit -m "备注信息")

  上面简化方法: git commit -am "备注信息"

  3.远程拉取和推送

  查看远程仓库的地址:git remote -v 查看远程仓库和本地关联了的地址

  关联某个关联的仓库:git remote add origin github地址

  移除某个关系仓库的地址: git remote rm origin github地址

  推送本地代码到远程:git push -u origin master(第一次推送加-u,都叫master可以省略,只写一个master即可)

  拉取远程到本地:git pull orgin master 拉取远程仓库代码并合并

  4.解决本地远程仓库不关联的问题(即本地仓库已经不是拉取的而是建立的)

  首先关联地址:git remote add origin github地址  -> 允许两个不相关的文件进行融合:git pull origin master --allow-unrelated-histories ->提交到远程 git push --set-upstream origin master

  5.查看本地修改的记录(多用于版本回退)

  git log --oneline(建议用这个比较简洁)

 

(五)版本回退

  git reset --hard HEAD 回到当前的版本

  git reset --hard HEAD^ 回到当前的版本前一个版本

  git reset --hard HEAD^^ 回到当前的版本前两个版本

  git reset --hard af4542g(使用git log --online 获取日志的前7位,可以回到指定的版本)

  git checkout 文件名  撤掉修改(这个只能在没有提交到本地仓库前使用)

(六)解决冲突

  1.解决文件修改了相同位置的冲突

   要先从远程拉取代码下来 git pull ---> 接着在根据提示进入到你想要文件中去合并代码 再次提交就可以解决了

(七)分支管理

  查看当前分支:  git branch

  新增分支   git branch 分支名

  切换分支 git checkout 分支名

  合并分支到master先切换到master分支git merge --no-f dev -m "备注" //把dev分支合并到master,合并也是一个分支

(八)其余的技巧

  查看当前版本  git tag

  新增版本号 git tag v1.0 -m "备注信息"

  推送一个版本同时带版本  git push origin master --tag

  git rm 文件名   //删除文件

  ssh-keygen //一路回车就行接着在远程的设置公钥

  忽略版本控制中的某个文件,不上传新增.gitignore 文件 内容就是想忽略的文件

  别名的设置:  例如:git config --global alias.co checkout

git的那些事的更多相关文章

  1. 关于Git的那些事

    以前一直使用tfs 或者svn当做代码管理器,随着GitHub的越来越火,git的使用人说也越来越多,这不我也开始来折腾git .GitHub的连接速度有的时候很慢,在国内不是太稳定,正好看到开源中国 ...

  2. 关于我学git这档子事

    创建本地分支并切换到该分支 git checkout -b *** 相当于如下2个命令: git branch *** git checkout *** 推送本地开发分支到远程开发分支 git pus ...

  3. 关于我学git这档子事(5)

    对于错误: fatal: refusing to merge unrelated histories 解决之道: git pull origin main --allow-unrelated-hist ...

  4. 关于我学git这档子事(4)

    ------------恢复内容开始------------ 当本地分支(main/dev)比远程仓库分支(main/dev)落后几次提交时 先: git pull 更新本地仓库 再 git push ...

  5. 关于我学git这档子事(3)

    对于如下报错: hint: Updates were rejected because a pushed branch tip is behind its remote hint: counterpa ...

  6. 关于我学git这档子事(2)

    将本地main分支push到远程dev分支(不同名分支间的push) 远程dev分支还未创建 (在push同时创建远程dev分支,并将本地main分支内容上传) git push -u --set-u ...

  7. git笔记

    这篇有关git的博客,写着写着有些崩了.里面有些碎碎念了.下次一定注意这个问题. 创建项目: midir xx :创建xx文件夹 git init : 为当前文件夹创建代码仓库 提交代码: git a ...

  8. Git管理工具对照(GitBash、EGit、SourceTree)

    Git管理工具对照(GitBash.EGit.SourceTree) GitBash是採用命令行的方式对版本号进行管理,功能最为灵活强大,可是由于须要手动输入希望改动的文件名称,所以相对繁琐. EGi ...

  9. Git管理工具对比(GitBash、EGit、SourceTree)

    Git管理工具对比(GitBash.EGit.SourceTree) GitBash是采用命令行的方式对版本进行管理,功能最为灵活强大,但是由于需要手动输入希望修改的文件名,所以相对繁琐. EGit是 ...

随机推荐

  1. MT【263】待定系数

    已知$a,b>0$且$ab(a+b)=4$,求$2a+b$的最小值_____ 解答:$\sqrt{3}(2a+b)\ge(\sqrt{3}+1)a+b+(\sqrt{3}-1)(a+b)\ge3 ...

  2. MongoDB 数据恢复与导出

    MongoDB登录mongo --host localhost --port 27017 -uroot -pdbpasswd --authenticationDatabase admin查看所有dbs ...

  3. Hdoj 2190.悼念512汶川大地震遇难同胞——重建希望小学 题解

    Problem Description 下面是512汶川大地震部分受灾学校伤亡情况(惨痛!!) 1. 四川省都江堰市 聚源中学 伤亡情况:遇难学生人数(含失踪)320 详细说明: 一栋教学楼被震垮,该 ...

  4. ZJOI 2019 划水记

    作为一个极其蒟蒻的OIer,虽然没有省选资格但还是去见见世面. ZJOI2019一试是在浙江省镇海中学.听名字就很霸气. 学习OI的最后一年,记录下一些事情,即使最终走到最后也一无所获,也是一段美好的 ...

  5. [luogu3810][bzoj3262]陌下花开【cdq分治】

    题目描述 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),用三个整数表示.现在要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义一朵花A比另一朵花B要美丽,当且仅Sa&g ...

  6. MySQL数据库的基本使用简单易懂

    MySQL数据库的基本使用 一.数据库概述 1. 基本介绍 数据库就是以一定格式进行组织的数据的集合.通俗来看数据库就是用户计算机上 一些具有特殊格式的数据文件的集合 2. 数据库的特点 持久化存储 ...

  7. jqgrid 时间戳转换成日期格式

    原文 :http://blog.csdn.net/caoyuancsdn/article/details/52984524 Java script  接收到的时间参数是时间戳*1000 functio ...

  8. Building real-time dashboard applications with Apache Flink, Elasticsearch, and Kibana

    https://www.elastic.co/cn/blog/building-real-time-dashboard-applications-with-apache-flink-elasticse ...

  9. 洛谷P1896 互不侵犯

    又是一道状压DP求方案数的题... 多了一个放k个的限制,于是我们把数组多开一维. f[i][j][k]表示前i行放了j个,第i行状态为k的方案数. 然后老套路DFS转移,这次要多记录一个cnt表示上 ...

  10. Linux基本命令总结(二)

    接上篇: 7,cp命令用来复制文件或者目录,是Linux系统中最常用的命令之一.一般情况下,shell会设置一个别名,在命令行下复制文件时,如果目标文件已经存在,就会询问是否覆盖,不管你是否使用-i参 ...