git的那些事
前言:记得在想学习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的那些事的更多相关文章
- 关于Git的那些事
以前一直使用tfs 或者svn当做代码管理器,随着GitHub的越来越火,git的使用人说也越来越多,这不我也开始来折腾git .GitHub的连接速度有的时候很慢,在国内不是太稳定,正好看到开源中国 ...
- 关于我学git这档子事
创建本地分支并切换到该分支 git checkout -b *** 相当于如下2个命令: git branch *** git checkout *** 推送本地开发分支到远程开发分支 git pus ...
- 关于我学git这档子事(5)
对于错误: fatal: refusing to merge unrelated histories 解决之道: git pull origin main --allow-unrelated-hist ...
- 关于我学git这档子事(4)
------------恢复内容开始------------ 当本地分支(main/dev)比远程仓库分支(main/dev)落后几次提交时 先: git pull 更新本地仓库 再 git push ...
- 关于我学git这档子事(3)
对于如下报错: hint: Updates were rejected because a pushed branch tip is behind its remote hint: counterpa ...
- 关于我学git这档子事(2)
将本地main分支push到远程dev分支(不同名分支间的push) 远程dev分支还未创建 (在push同时创建远程dev分支,并将本地main分支内容上传) git push -u --set-u ...
- git笔记
这篇有关git的博客,写着写着有些崩了.里面有些碎碎念了.下次一定注意这个问题. 创建项目: midir xx :创建xx文件夹 git init : 为当前文件夹创建代码仓库 提交代码: git a ...
- Git管理工具对照(GitBash、EGit、SourceTree)
Git管理工具对照(GitBash.EGit.SourceTree) GitBash是採用命令行的方式对版本号进行管理,功能最为灵活强大,可是由于须要手动输入希望改动的文件名称,所以相对繁琐. EGi ...
- Git管理工具对比(GitBash、EGit、SourceTree)
Git管理工具对比(GitBash.EGit.SourceTree) GitBash是采用命令行的方式对版本进行管理,功能最为灵活强大,但是由于需要手动输入希望修改的文件名,所以相对繁琐. EGit是 ...
随机推荐
- Django+Xadmin打造在线教育系统(九)
xadmin的进阶开发 因版本问题.有些配置可能无效 自定义icon xadmin的图标采用的是第三方css样式font awesome,我们可以进官网下载最新的样式替代原本的,下载地址:http:/ ...
- Matplotlib学习---用seaborn画矩阵图(pair plot)
矩阵图非常有用,人们经常用它来查看多个变量之间的联系. 下面用著名的鸢尾花数据来画一个矩阵图.从sklearn导入鸢尾花数据,然后将其转换成pandas的DataFrame类型,最后用seaborn画 ...
- Katu Puzzle POJ - 3678(水2 - sat)
题意: 有n个未知量,m对未知量之间的关系,判断是否能求出所有的未知量且满足这些关系 解析: 关系建边就好了 #include <iostream> #include <cstdio ...
- 关于360插件化Replugin Activity动态修改父类的字节码操作
近期在接入360插件化方案Replugin时,发现出现崩溃情况. 大概崩溃内容如下: aused by: java.lang.ClassNotFoundException: Didn't find c ...
- android设置透明度代码片段
我们可以在代码中完成对窗体透明度(这是窗体本身的透明度,非背景)的设置,方法如下: WindowManager.LayoutParams windowLP = getWindow().getAttr ...
- 【BZOJ3142】[HNOI2013]数列(组合计数)
[BZOJ3142][HNOI2013]数列(组合计数) 题面 BZOJ 洛谷 题解 唯一考虑的就是把一段值给分配给\(k-1\)天,假设这\(k-1\)天分配好了,第\(i\)天是\(a_i\),假 ...
- python实用脚本集
iScript 是Github上 PeterDing 大神写的一个脚本集,由多数的 python 脚本和少数GM脚本组成. 含有以下几个脚本: xiami.py - 下载或播放高品质虾米音乐(xiam ...
- [SDOI2011]消防
某个国家有n个城市,这n个城市中任意两个都连通且有唯一一条路径,每条连通两个城市的道路的长度为zi(zi<=1000). 这个国家的人对火焰有超越宇宙的热情,所以这个国家最兴旺的行业是消防业.由 ...
- CSS之2D转换模块
CSS 2D转换模块 transform 参考W3手册 transform 属性向元素应用从2D 或3D转换.该属性允许我们对元素进行旋转.缩放.移动或者倾斜. 格式: transform: none ...
- Python3 与 C# 面向对象之~异常相关
周末多码文,昨天晚上一篇,今天再来一篇: 在线编程:https://mybinder.org/v2/gh/lotapp/BaseCode/master 在线预览:http://github.les ...