Git实际使用
初始化
git init
— cd到目录,初始化仓库
git init name
— 新建文件,并初始化仓库
.gitignore
— 忽略文件(https://github.com/github/gitignore)
git config —global credential helper store
— 记录提交的密码进行缓存
------------------------------------------------------------------------------------------------------------
远程仓库
git remote -v
-- 查看所有远程仓库
git remote
--
------------------------------------------------------------------------------------------------------------
重命名
git mv oldname newname
— 重命名文件
mv oldname newname
git add .
— 重命名文件 ,新增至暂存区
------------------------------------------------------------------------------------------------------------
日志
git log --all
— 所有分支日志
git log -p -2 dev
— dev 分支最新提交日志 对比信息
git log --stat
— 简要信息
git log --pretty=oneline
— 显示成一行
git log -n4
— 当前分支就近的4个
git log --all -n4
— 所有分支的就近的4个
git log -n4 dev
— dev 分支下的就近4个
git log --oneline
— 简洁日志
git log --graph
— 图形化入日志
gitk
— 图形化工具
------------------------------------------------------------------------------------------------------------
暂存区
git add 文件
— 文件添加至缓存区
git add .
— 新建的文件、修改的文件、删除的文件,添加至缓存区
git add -u
— 将已跟踪的文件(修改、删除),添加至缓存区
git add -A
git add -all
git add -a
— 新建的文件、修改的文件、删除的文件,添加至缓存区
------------------------------------------------------------------------------------------------------------
分支
git branch -a
— 查看本地分支情况,远程分支情况
git branch -av
— 查看本地分支 以及相互关系
git checkout branchName
— 切换分支
git checkout -b newBranch
— 从当前本地分支 创建分支,并切换到新分支
— 复制当前分支,命名为 newBranch
git checkout -b newBranch otigin/branch
— 从远程分支检出到新分支
git branch -d <branchname>
— 删除分支
git branch -D <branchname>
— 强制删除分支
git ls-remote
— 远程分支信息
------------------------------------------------------------------------------------------------------------
提交
git commit -m "备注"
— 提交到待推送区域
git commit -am "备注"
— 添加到暂存区,并提交到待推送区域
git commit --amend
— 修改当前分支,最近一次提交的备注
------------------------------------------------------------------------------------------------------------
比较
git diff --catch
— 暂存区 和 HEAD比较
gti diff
— 工作区 和 暂存区 比较
git diff HEAD
— 工作区 和 HEAD比较
------------------------------------------------------------------------------------------------------------
撤销
git reset --hard
— 暂存区、工作区 恢复成 HEAD
git reset --hard 23ur9wi
— HEAD 指向这个commit,同时 缓存区、工作区内容也恢复到这个commit
git reset HEAD
— 缓存区与HEAD一样
git checkout .
— 工作区 与 缓存区一样
git checkout HEAD .
— 工作区、缓存区 和 HEAD一样
git checkout HEAD <filename>
— 检出当前分支提交的最新版本
— 覆盖 暂存区,即撤销暂存区
— 覆盖 工作区,撤销修改
------------------------------------------------------------------------------------------------------------
删除
git rm 文件 --hard HEAD
— 删除文件,工作区和缓存区恢复到HEAD
git rm --cached <firename>
— 删除 已提交的跟踪文件
------------------------------------------------------------------------------------------------------------
打标签
------------------------------------------------------------------------------------------------------------
分离头指针
根据某一个 commit 检出
现在就处于分离头指针的情况下,HEAD -> commit
Git实际使用的更多相关文章
- Git 子模块 - submodule
有种情况我们经常会遇到:某个工作中的项目需要包含并使用另一个项目. 也许是第三方库,或者你 独立开发的,用于多个父项目的库. 现在问题来了:你想要把它们当做两个独立的项目,同时又想在 一个项目中使用另 ...
- Git 在团队中的最佳实践--如何正确使用Git Flow
我们已经从SVN 切换到Git很多年了,现在几乎所有的项目都在使用Github管理, 本篇文章讲一下为什么使用Git, 以及如何在团队中正确使用. Git的优点 Git的优点很多,但是这里只列出我认为 ...
- Git与Repo入门
版本控制 版本控制是什么已不用在说了,就是记录我们对文件.目录或工程等的修改历史,方便查看更改历史,备份以便恢复以前的版本,多人协作... 一.原始版本控制 最原始的版本控制是纯手工的版本控制:修改文 ...
- Git Bash的一些命令和配置
查看git版本号: git --version 如果是第一次使用Git,你需要设置署名和邮箱: $ git config --global user.name "用户名" $ gi ...
- 在Ubuntu 16.10 安装 git 并上传代码至 git.oschina.net
1. 注册一个账号和创建项目 先在git.oschina.net上注册一个账号和新建一个project ,如project name 是"myTest". 2.安装git sudo ...
- 史上最详细git教程
题外话 虽然这个标题很惊悚,不过还是把你骗进来了,哈哈-各位看官不要着急,耐心往下看 Git是什么 Git是目前世界上最先进的分布式版本控制系统. SVN与Git的最主要的区别 SVN是集中式版本控制 ...
- [版本控制之道] Git 常用的命令总结(欢迎收藏备用)
坚持每天学习,坚持每天复习,技术永远学不完,自己永远要前进 总结日常开发生产中常用的Git版本控制命令 ------------------------------main-------------- ...
- 【解决方案】Myeclipse 10 安装 GIT 插件 集成 步骤 图解
工程开发中,往往要使用到集成GIT ,那么下面说说插件安装步骤 PS:以Myeclipse 10 为例,讲解集成安装步骤. ----------------------main------------ ...
- git 命令
切换仓库地址: git remote set-url origin xxx.git切换分支:git checkout name撤销修改:git checkout -- file删除文件:git rm ...
- git亲测命令
一.Git新建本地分支与远程分支关联问题 git checkout -b branch_name origin/branch_name 或者 git branch --set-upstream bra ...
随机推荐
- JavaWeb(四)Servlet-1
1.Servlet 简介 Java Servlet是和平台无关的服务器端组件,它运行在Servlet容器中.Servlet容器负责Servlet和客户的通信以及调用Servlet的方法,Servlet ...
- range与enumerate的区别
在迭代中enumerate比range更能灵活,一般情况下尽量用erumerate,下面举例说明: 先来看range的使用: city_list = ['beijing', 'shanghai', ' ...
- java.lang.IllegalArgumentException异常 返回值类型的问题
java.lang.IllegalArgumentException: Cannot create TypedQuery for query with more than one return usi ...
- BZOJ_5296_[Cqoi2018]破解D-H协议_BSGS
BZOJ_5296_[Cqoi2018]破解D-H协议_BSGS Description Diffie-Hellman密钥交换协议是一种简单有效的密钥交换方法.它可以让通讯双方在没有事先约定密钥(密码 ...
- Java基础系列--基础排序算法
原创作品,可以转载,但是请标注出处地址:https://www.cnblogs.com/V1haoge/p/9082138.html 一.概述 基础排序算法包括:桶排序.冒泡排序.选择排序.插入排序等 ...
- LVS+keepalived负载均衡
背景: 随着你的网站业务量的增长你网站的服务器压力越来越大?需要负载均衡方案!商业的硬件如F5又太贵,你们又是创业型互联公司如何有效节约成本,节省不必要的浪费?同时实现商业硬件一样的高 ...
- Linux vim常用命令
什么是 vim? Vim是从 vi 发展出来的一个文本编辑器.代码补完.编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用. 简单的来说, vi 是老式的字处理器,不过功能已经很齐全了,但是 ...
- 【CTF 攻略】CTF比赛中关于zip的总结
[CTF 攻略]CTF比赛中关于zip的总结 分享到: --> 本文首发于安全客,建议到原地址阅读,地址:http://bobao.360.cn/ctf/detail/203.html 前言 ...
- mysql5.7连接不上可能的问题(针对新安装的mysql5.7可能出现的问题)
"ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)" 今天刚刚安装好的mysql5. ...
- 隐马尔可夫模型(HMM)总结
摘要: 1.算法概述 2.算法推导 3.算法特性及优缺点 4.注意事项(算法过程,调参等注意事项) 5.实现和具体例子 6.适用场合 内容: 1.算法概述 隐马尔科夫模型(Hidden Markov ...