新手向–git版本控制器

Git 版本控制器

(本文档由XDL讲师黄超,使用MarkDown构建而改为,转载请注明出处)

<div id="wrapper">
  <div id="iphone">
    <div id="side"></div>
    <div id="lines">
      <div>
        <div>
          <div></div>
        </div>
      </div>
      <div>
        <div>
          <div></div>
        </div>
      </div>
    </div>
    <div id="toggler">
      <div></div>
    </div>
    <div id="aux"></div>
    <div id="lightning"></div>
    <div id="bottom-speaker">
      <div></div>
      <div></div>
      <div></div>
      <div></div>
      <div></div>
      <div></div>
      <div></div>
    </div>
    <div id="skrews">
      <div></div>
      <div></div>
    </div>
    <div id="volume">
      <div></div>
      <div></div>
    </div>
    <div id="front">
      <div id="front-cover"></div>
      <div id="camera">
         <div></div>
      </div>
      <div id="speaker"></div>
      <div id="screen">
        <div id="reminder">
          <div></div>
          <div>Made by @_fbrz</div>
          <div>now</div>
        </div>
        <div id="circle"></div>
        <div id="time">12:42</div>
        <div id="date">Saturday, January 4</div>
        <div id="bottom"></div>
        <div id="top"></div>
        <div id="slide">
          <div></div>
          slide to unlock
        </div>
        <div id="signal">
          <div></div>
          <div></div>
          <div></div>
          <div></div>
          <div></div>
        </div>
        <div id="battery">
          <div>86%</div>
          <div>
            <div></div>
            <div></div>
          </div>
        </div>
      </div>
      <div id="home">
        <div></div>
      </div>
    </div>
    <div id="shadow"></div>
  </div>
</div>

9.1. 当地生成SSH密钥

1). 本地打开git bash
,cd切换到用户之寒目录
2). 使用pwd来查目录是否对
3). 使用 ssh-keygen.exe -t rsa
来生成SHA256之SSH密钥(按回车确认即可)
4). cd .ssh/
切换至ssh目录
5). ls 查看目录下文件
6). cat id_rsa.pub
查看转的密钥,并复制

7). 打开git@osc开源中国,登录自己之账户.点选个人资料
8). 选择SSH公钥
9).
在添加公钥界面,将正复制好之密钥粘贴进来,再好赢得一个该密钥的讳,以便为分别管理

10). 本地新建一个目,用于拉取远端版本库
11). 使用
git init初始化该目录
12). 使用git remote add origin <SSH地址>
来添加远程版本库

13). 使用git remote -v
来查看远程版本库信息
14). 使用git pull origin marster来拉取版本库及代码


Git常用命令速查

  • master 默认主分支
  • dev 默认开发分支

创造版本库

git init
# 初始化本地git版本库(创建新仓库)

git config --global user.name "xxx"
# 配置用户名

git config --global user.email "xxx@xxx.com"
# 配置邮件

git config --list
#查看当前配置列表

git clone <url>
# clone远程仓库

 

修改、提交、删除

git add index.php
# 添加index.php文件到缓存区
git add .
# 添加所有改动过的文件到缓存区
git add --all
# 添加所有文件到缓存区

git commit
# 提交缓存区内的文件(回车后需要键入描述:wq保存退出)
git commit -m "描述"
# 提交缓存区内的文件,并提供描述

git commit -am '描述'
# 将add和commit合为一步
git commit --amend -m 'xxx'
# 合并最后一次提交(用于反复修改)

git rm index.php
# 删除index.php文件
git rm --cached index.php
# 将index.php文件移出缓存区,但不删除( -r * 递归目录)
git rm -f 1.html
# 将缓存区中的1.html文件移出并删除

 

查看

git status
# 查看当前版本状态(是否修改)

git diff
# 查看所有添加到缓存区的变更(工作区与版本库的区别)
git diff index.php
# 查看工作区文件和库文件区别
git diff --cached
# 查看所有已添加到缓存区,但还未commit的变更(缓存区与版本库的区别)

git log
# 查看提交历史
git log --oneline
# 以简短的方式查看提交日志

git reflog
# 行为日志,显示所有提交,回滚等..
git ls-files
# 显示缓存区的所有文件

 

回退 与 撤销

git reset --hard HEAD
# 将当前版本重置为HEAD(通常用于merge失败回退)

git reset --hard HEAD^   # 回退上一个版本
git reset --hard HEAD^^  # 回退上两个版本
git reset --hard HEAD~n  # 回退上n个版本

git reset --hard <commitid>
# 回退指定版本,commitid根据log获取

git checkout --filename
# 在工作区撤销文件的修改
git checkout HEAD [filename]
# 撤回添加至缓存区的修改,不指定filename则撤回所有

 

子操作

git pull origin master
# 获取远程分支master并merge到当前分支

git branch
# 显示本地分支
git branch -a
# 显示所有分支
git checkout 分支名/标签名
# 切换到指定分支或标签

git branch 分支名
# 新建分支
git branch -d 分支名
# 删除本地分支 -D 强制删除

 

远程协作

git remote add <remote> <url>
# 添加远程版本库
git remote -v
# 查看远程版本库信息
git remote show <remote>
# 查看指定远程版本库信息
git remote remove <name>
# 删除远程remote链接
git remote rename <old> <new>
# 重命名远程链接名

git pull <remote> <branch>
# 下载代码及快速合并

git push <remote> <branch>
# 上传代码及快速合并

git merge origin master
# 将本地的远端库合并

git fetch origin
# 将远端库获取本地但不合并

 

CSS3值得学习,小伙伴等可研究一下。

5.2 配置

无论Linux还是Windows,安装好后还设初始化

git config [--global] user.name "Your Name"
git config [--global] user.email "your@email.com"

 

中括号内的参数:

 --local 本地
    --system 系统
    --global 全局
    无参,则为当前库配置身份

 

@font-face {
    font-family: Helvetica;
    src: url(https://s3-us-west-2.amazonaws.com/s.cdpn.io/164210/HelveticaNeue-UltraLight.otf) format('TrueType');
  font-weight: 300;
}

body {
  font-family: 'Helvetica', sans-serif;
  background: #f5f5f5;
  color: #333;
  letter-spacing: 1px;
}
html,body {
  height: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

#wrapper {
  height: 520px;
  width: 800px;
  margin-left: -400px;
  margin-top: -260px;
  position: absolute;
  perspective: 6000px;
  top: 50%;
  left: 50%;
}
#iphone {
  height: 760px;
  width: 372px;
  border-radius: 50px;
  position: absolute;
  background: none; 
  box-shadow: none;
  left: 206px;
  top: -140px;
  transform: rotateX(54deg) rotateZ(-46deg);
  transform-style: preserve-3d;
}
#side {
 background: #CDD0D5;
  width: 393px;
  height: 780px;
  border-top-left-radius: 77px;
  border-bottom-left-radius: 49px;
  border-bottom-right-radius: 86px;
  border-top-right-radius: 70px;
  position: absolute;
  top: 5px;
  left: -26px;
  box-shadow: inset #3D3E42 0 0 15px 9px;
}
#front {
  width: 362px;
  height: 750px;
  border-radius: 49px;
  position: absolute;
  background-image: -webkit-linear-gradient(-27deg,#444,#000 10%, #000 42%, #333, #000 57%, #000 91%, #444);
  left: 5px;
  top: 5px;
  box-shadow: inset #000 0 0 0 4px, #555 0px 0 3px 0px, #222 -3px 2px, #000 -5px 5px, #E0E0E0 -7px 6px 1px, #6D6D6D -7px 6px 9px;
   transform: translateZ(1px);
}
#front-cover {
  width: 344px;
  height: 734px;
  background: #000;
  border-radius: 39px;
  position: absolute;
  top: 8px;
  left: 9px;
}

#home {
  position: absolute;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(32deg,#666,#000,#666);
  top: 684px;
  left: 160px;
}
#home div {
  background: #000;
  border-radius: 50%;
  width: 46px;
  height: 46px;
  position: absolute;
  left: 3px;
  top: 3px;
}

#camera {
  width: 11px;
  height: 11px;
  background: #000;
  position: absolute;
  top: 35px;
  left: 124px;
  border-radius: 50%;
  box-shadow: inset #666 -5px 2px 9px -2px;
}
#camera div {
  width: 6px;
  height: 6px;
  background: radial-gradient(#E1E4F5,#0D2B69 33%);
  background-position: -1px -1px;
  position: absolute;
  top: 3px;
  left: 3px;
  border-radius: 50%;
}

#speaker {
  width: 50px;
  height: 4px;
  border-radius: 2px;
  background: #555;
  position: absolute;
  top: 39px;
  left: 156px;
  box-shadow: inset #222 0 0px 4px;
}

#volume {
  height: 128px;
  width: 11px;
  border-radius: 10px;
  position: absolute;
  background: #F9F9FA;
  top: 171px;
  left: -20px;
  transform: rotateY(95deg);
  transform-style: preserve-3d;
  box-shadow: inset #292A2F 4px 0 8px 1px, #D5D5D5 -1px 0px 2px;
}
#volume div {
  width: 8px;
  height: 55px;
  background: #BBBCC0;
  border-radius: 10px;
  position: absolute;
  box-shadow: #eee -1px 1px, #777 -1px 3px,  #505057 -3px 3px, inset #909197 -3px 0 3px;
}

#volume div:first-child {
  top: 2px;
  left: 4px;
}
#volume div:last-child {
  top: 69px;
  left: 4px;
}

#toggler {
  height: 34px;
  width: 8px;
  border-radius: 10px;
  position: absolute;
  background: #2B2C31;
  top: 105px;
  left: -20px;
  transform: rotateY(95deg);
  transform-style: preserve-3d;
  box-shadow: inset #292A2F 4px 0 8px 1px, #D5D5D5 -1px 0px 2px;
}
#toggler div {
  width: 4px;
  height: 31px;
  background: #BBBCC0;
  border-radius: 10px;
  position: absolute;
  box-shadow: #eee -1px 1px, #777 -2px 3px, #505057 -3px 3px, inset #909197 -3px 0 3px;
  top: -1px;
  left: 3px;
}

#aux {
  width: 19px;
  height: 19px;
  background: #3B3B3B;
  border-radius: 50%;
  transform: rotateX(90deg) translateZ(1px);
  transform-style: preserve-3d;
  position: absolute;
  top: 766px;
  left: 45px;
  box-shadow: inset #000 6px -3px 10px 1px, #C7C7C7 1px 0px 1px;
}

#lightning {
  width: 48px;
  height: 12px;
  border-radius: 10px;
  background: #3F3F3F;
  transform: rotateX(90deg) translate3d(0px,1px,0px);
  top: 771px;
  position: absolute;
  left: 139px;
  box-shadow: inset #8E8F94 -1px 1px 0px 2px, #515258 0px 0px 0 1px, inset #000 0 -3px 10px, #DADADA 1px 0 0 1px;
}

#bottom-speaker {
  position: absolute;
  transform: rotateX(90deg);
  top: 781px;
  left: 70px;
}
#bottom-speaker div {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #6C6D72;
  position: absolute;
  box-shadow: inset #000 1px -1px 4px 1px, #DADADA 1px 0px;
}
#bottom-speaker div:nth-child(2) { left: 150px; }
#bottom-speaker div:nth-child(3) { left: 162px; }
#bottom-speaker div:nth-child(4) { left: 174px; }
#bottom-speaker div:nth-child(5) { left: 186px; }
#bottom-speaker div:nth-child(6) { left: 198px; }
#bottom-speaker div:nth-child(7) { left: 210px; }

#skrews {
  position: absolute;
  top: 780px;
  left: 120px;
  transform: rotateX(90deg);
}
#skrews div {
  position: absolute;
  width: 8px;
  height: 8px;
  background: rgb(95, 92, 92);
  border-radius: 50%;
  top: 0;
  z-index: 4;
  box-shadow: inset #999AA0  0 0 0px 2px, #444 1px 0px;
}

#skrews div:last-child {
  left: 70px;
}

#lines {
  position: absolute;
  top: 82px;
  left: -32px;
}
#lines > div:last-child {
  top: 634px;
}

#lines div {
  width: 7px;
  height: 11px;
  position: absolute;
  transform-style: preserve-3d;
  transform-origin: 100% 100%;
}

#lines > div {
  background: linear-gradient(right,#393A3C,#5A595E);
  transform: rotateY(90deg);
}
#lines > div > div {
  background: linear-gradient(right,#5A595E,#87868A);
  transform: rotateY(17deg);
  left: -6px;
}
#lines > div > div > div {
  background: linear-gradient(right,#87868A,#A8A6AD);
  transform: rotateY(17deg);
  left: -6px;
}

#shadow {
  width: 350px;
  height: 755px;
  background: black;
  position: absolute;
  top: 5px;
  left: 0;
  transform: translateZ(-17px);
  transform-style: preserve-3d;
  box-shadow: #000 0 0 10px 15px;
  opacity: 0.4;
  border-top-left-radius: 76px;
  border-top-right-radius: 200px;
  border-bottom-left-radius: 40px;
  border-bottom-right-radius: 56px;
}

#screen {
  background: linear-gradient(#A1E5E5,#1987AA);
  width: 336px;
  height: 589px;
  position: absolute;
  top: 80px;
  left: 13px;
  font-weight: 300;
  color: #fff;
  background-size: 200% 100%;
  overflow: hidden;
}

#time {
  font-size: 86px;
  left: 57px;
  top: 37px;
  position: absolute;
}
#date {
  font-size: 20px;
  left: 85px;
  top: 130px;
  position: absolute;
}

#bottom {
  width: 37px;
  height: 7px;
  border-radius: 5px;
  background: #2AB1DB;
  position: absolute;
  top: 573px;
  left: 149px;
}
#top {
  width: 37px;
  height: 7px;
  border-radius: 5px;
  background: #D7FFFF;
  position: absolute;
  top: 10px;
  left: 149px;
}
#slide {
  position: absolute;
  top: 489px;
  left: 88px;
  font-size: 28px;
  color: #2AB1DB;
  background: linear-gradient(left,#2EC4F3 30%,#fff,#2EC4F3 70%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-size: 350px;
  animation: slide 5s linear infinite;
}

@keyframes slide {
  0% { background-position: 100px 0; }
  40% { background-position: 440px 0; }
  100% { background-position: 440px 0; }
}

#slide div {
  transform: rotate(135deg);
  border-left: 2px solid #2AB1DB;
  border-top: 2px solid #2AB1DB;
  width: 15px;
  height: 15px;
  position: absolute;
  left: -29px;
  top: 10px;
}

#signal {
  position: absolute;
  top: 9px;
  left: 7px;
}
#signal div {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid #fff;
  position: absolute;
}
#signal div:nth-child(2) {
  left: 9px;
}
#signal div:nth-child(3) {
  left: 18px;
}
#signal div:nth-child(4) {
  left: 27px;
}
#signal div:nth-child(5) {
  left: 36px;
  background: none;
}

#battery {
  position: absolute;
  top: 3px;
  left: 270px;
  font-size: 13px;
}
#battery > div:last-child {
  width: 27px;
  height: 9px;
  border: 1px solid #fff;
  position: absolute;
  top: 4px;
  left: 27px;
  border-radius: 2px;
}
#battery div div:first-child {
  width: 21px;
  height: 7px;
  background: #fff;
  position: absolute;
  top: 1px;
  left: 1px;
}
#battery div div:last-child {
  width: 1px;
  height: 6px;
  background: #FFF;
  position: absolute;
  left: 29px;
  top: 2px;
  border-radius: 0 1px 1px 0;
}

#fabrizio {
    border-top: 100px solid black; 
    border-right: 63px solid transparent;
    width: 0;
    transform: scale(.33);
    transform-origin: 0 0;
    margin: 20px;
    opacity:.6;
  position: absolute;
  bottom: -130px;
}
#fabrizio:before {
    background: black;
    width: 20px;
    height: 30px;
    content: '';
    display: block;
    transform: skewX(-32deg);
    position: relative;
    top: -65px;
    left: 29px;
}
#fabrizio:after {
    background: black;
    width: 40px;
    height: 36px;
    content: '';
    display: block;
    transform: skewX(-32deg);
    position: relative;
    top: -130px;
    left: 49px;
}

#circle {
  width: 50px;
  height: 50px;
  background: none;
  border-radius: 50%;
  box-shadow: rgba(255,255,255,0.1) 160px 335px,rgba(255,255,255,0.1) 120px 275px 0 12px,rgba(255,255,255,0.1) 60px 355px 0 23px,rgba(255,255,255,0.1) 230px 445px 0 -8px,rgba(255,255,255,0.1) 60px 125px,rgba(255,255,255,0.1) 260px 145px 0 12px,rgba(255,255,255,0.1) 300px 145px 0 23px,rgba(255,255,255,0.1) 100px 85px 0 -8px,rgba(255,255,255,0.1) 50px 155px,rgba(255,255,255,0.1) 150px 273px 0 -2px,rgba(255,255,255,0.1) 50px 555px 0 23px,rgba(255,255,255,0.1) 180px 5px 0 -8px;
  animation: circle 30s linear infinite alternate;
}

@keyframes circle {
  0%{
    box-shadow: rgba(255,255,255,0.1) 160px 335px,rgba(255,255,255,0.1) 120px 275px 0 12px,rgba(255,255,255,0.1) 60px 355px 0 23px,rgba(255,255,255,0.1) 230px 445px 0 -8px,rgba(255,255,255,0.1) 60px 125px,rgba(255,255,255,0.1) 260px 145px 0 12px,rgba(255,255,255,0.1) 300px 145px 0 23px,rgba(255,255,255,0.1) 100px 85px 0 -8px,rgba(255,255,255,0.1) 350px 555px,rgba(255,255,255,0.1) 350px 273px 0 -2px,rgba(255,255,255,0.1) 150px 355px 0 23px,rgba(255,255,255,0.1) 180px 205px 0 -8px,rgba(255,255,255,0.1) 0px 0px 0 -8px,rgba(255,255,255,0.1) 100px 555px 0 10px;
  }
  100%{
    box-shadow: rgba(255,255,255,0.1) 70px 10px,rgba(255,255,255,0.1) 300px 205px 0 12px,rgba(255,255,255,0.1) 0px 155px 0 23px,rgba(255,255,255,0.1) 330px 45px 0 -8px,rgba(255,255,255,0.1) 460px 325px,rgba(255,255,255,0.1) 0px 445px 0 12px,rgba(255,255,255,0.1) 300px 145px 0 23px,rgba(255,255,255,0.1) 100px 85px 0 -8px,rgba(255,255,255,0.1) 50px 155px,rgba(255,255,255,0.1) 150px 273px 0 -2px,rgba(255,255,255,0.1) 0px 555px 0 23px,rgba(255,255,255,0.1) 180px 5px 0 -8px,rgba(255,255,255,0.1) 300px 555px 0 -8px,rgba(255,255,255,0.1) 350px 355px 0 10px;
  }
}

#reminder {
  position: absolute;
top: 230px;
left: 40px;
width: 296px;
height: 50px;
border-top: 1px solid #86E2F0;
border-bottom: 1px solid #86E2F0;
line-height: 50px;
font-weight: 400;
  opacity: 0;
  animation: reminder .1s linear forwards 15s;
}
#reminder div:first-child {
  background: #fff;
  width: 16px;
  height: 16px;
  border-radius: 3px;
  position: absolute;
  top: 18px;
}
#reminder div:nth-child(2) {
  position: absolute;
  left: 30px;
}
#reminder div:last-child{
   position: absolute;
left: 251px;
font-size: 11px;
  color: #86E2F0;
}

@keyframes reminder {
  100% {
    opacity: 1;
  }
} 


#awwwards {
  position: absolute;
  bottom: 30px;
  left: 70px;
}
#awwwards a {
  color: #444;
  text-decoration: none;
  border-bottom: 1px solid #888;
}

#coolors {
  position: absolute;
  bottom: 30px;
  right: 30px;
  color: #444;
  text-decoration: none;
  border-bottom: 1px solid #888;
  animation: coolors 1s infinite;
  opacity: 1;
}
@keyframes coolors {
  50% { right: 40px; }
}

9. 下代码托管体系

市面上赫赫有名的Git托管系统 :

  • GitHub https://github.com/
  • 开源中国 https://git.oschina.net/

以下为开源中国呢条例,来学习运用

CSS代码如下:

6. Git常用操作

HTML结构代码如下:

Git问世

Git的第一个版本是Linux之父Linus
Torvalds亲手操刀设计和实现之(两到家内用C写了),Linus不仅仅让来一个原有设计,并在朝着世人介绍Git时明显批评了CVS和SVN等,Git消除了分支和联的害怕。很多巨型开源项目由于SVN迁移到Git。

2008年www.github.com也成世界最为可怜之SCM系统(软件配置管理),它使的饶是Git版本库的技术.从此Git成为版本控制系统的主流。

GitHub上的资深项目 :
Linux内核、安卓、jQuery、Bootstrap、Ruby …


6.6. 撤销

目的:将没有提交到本库底改动撤回。

  • 事态一致 : 文件修改后尚未加加到缓存区

    git checkout --filename
    # 在工作区撤销文件的修改
    

     

  • 景况二 : 文件修改都上加至缓存区

    git checkout HEAD [filename]
    # 撤回添加至缓存区的修改,不指定filename则撤回所有
    

     


iPhone
6发布不久,屌丝怎能选购得自,不过作为程序员,今天看一个因此纯CSS3绘制的iPhone
6,由于CSS3特性的使,带有点3D的卡通片特效,大家好先来探在线演示效果。

8.2. 创立分支/删除分支

git branch 分支名
# 新建分支
git checkout -b dev
# 创建并切换到dev分支

git branch -d 分支名
# 删除本地分支 -D 强制删除

 

在线演示     
  源码下载

2.什么是版本控制系统?

版本控制 — <<维基百科>>

版本控制是一致种软件工程技术,能当软件开发的进程被,确保由不同人所编纂的同一代码文件案都拿走同步.
版本控制能使项目的设计者,将项目恢复至事先任意的状态,这种选择权以计划过程遭到专门重要.
辩及拥有的消息记录还得添加版本控制:利用版本控制来追踪、维护源码、文件与配置文件等等的更改


3.版本控制发展史

1.什么是Git

当今世界最先进/最好用的分布式版本控制系统,没有有

3.2 集中式

概括仓库以及工作区两局部:工作区编码,再上传至库的主意形成差不多人合作。
题材:工作机与库机需要联网才能够控制版本,传输速度较慢。

8.5. 子管理策略


6.2.添加文书及版本库

  1. 新建文件 1.txt

  2. 查时版状态

    git status     #查看当前版本状态
    

     

  3. 红字提示有文件不跟(未在版本控制)

  4. 在工具外输入以下,添加文书及本本库:

    git add 1.txt
    # 添加文件至缓存区
    git commit -m "描述"
    # 提交文件至版本库
    
    git add newfile1 newfile2 ...
    # 多文件添加
    git commit -m "描述"
    # 将缓存区的多次添加一次提交
    
    ps:
    git add .
    # 添加所有改动过的文件到缓存区
    git add --all
    # 添加所有文件到缓存区
    

     

  5. 履行了晚,提示提交完成.

  6. git status 提示

    nothing to commit, working directory clean
    

     

  7. 时至今日最简便的长文件及版本库已成功


8.1. 翻看版本库分支

git branch
# 显示本地分支
git branch -a
# 显示所有分支
git checkout 分支名/标签名
# 切换到指定分支或标签

 

8.4. 缓解统一冲突

差不多分修改同一文件,合并或者出现冲。冲突有用<<<===>>>表示

化解方式:
先行手动修改冲突有,再次提交即可。


 

3.2 分布式

每台计算机都产生工作区和货栈自己支配版本,数据进一步安全,有逻辑上的中坚。


6.3.翻看文件修改状态相关

git status
# 查看当前版本状态(是否修改)

 

修改文件测试为下 :

git diff
# 查看所有添加到缓存区的变更(工作区与版本库的区别)
git diff index.php
# 查看工作区文件和库文件区别
git diff --cached
# 查看所有已添加到缓存区,但还未commit的变更(缓存区与版本库的区别)

 

Git日志,分析日志构成 :

git log
# 查看提交历史
git log --oneline
# 以简短的方式查看提交日志

 


— PS部分: Git 实现原理 —

  1. 干活区 : 就是程序员日常编写代码的公文夹
  2. 本子库 : 负责代码版本控制,就是.git隐藏目录
  3. 版本库原理图 :

版本库包括:暂存区(index/stage),HEAD(指针),分支(默看master主分支)等。

文本提交至版本库总共分点儿步:

1).git add filename # 添加至stage缓存区
2).git commit -m "描述" # 将stage的内容提交至版本库的master分支

 

实验:
改文件->查看状态->
丰富到缓存区->查看状态->
双重修改->提交->查看状态

翻看区别:
1). 修改文件->查看状态 :
显示红字,文件并未在缓存区(工作区修改,还无付诸至缓存区)
2). 添加至缓存区git add . -> 查看状态 : 显示绿字,已交付到缓存区
3). 继续修改文件->git commit -m "第1次修改 1.txt" ->
再次翻开状态 : 显示红字:文件发出改变未入到版本库

4).
这次提交,只是提交了add到缓存区之始末,第二糟糕修改的内容并从未add到缓存区,所以版本库与工作区文件不一致.
5). 此时需以目前之文书add到缓存区,再次提交即可

6.5. 行日志

git reflog
# 行为日志,显示所有提交,回滚等..
git ls-files
# 显示缓存区的所有文件

 


6.4. 版回退

git reset --hard HEAD
# 将当前版本重置为HEAD(通常用于清空缓存区,或merge失败回退)

git reset --hard HEAD^   # 回退上一个版本
git reset --hard HEAD^^  # 回退上两个版本
git reset --hard HEAD~n  # 回退上n个版本

git reset --hard <commitid>
# 回退到指定版本,commitid根据log获取

 


7.1. 得到远程的版本库

好行使有限种植艺术来博远程版本库:

  • 在某个指定的文书夹下下,即可取远端版本库及代码

    git clone <远端版本库url> <本地存放该库的文件夹名>
    

     

  • 手动添加版本库,并拉取文件

    git init
    #初始化本地仓库
    
    git remote add <remote> <url>
    # 添加远程版本库 <remote>可自行取名,默认origin
    
    git remote -v
    # 查看远程版本库信息
    git remote show <remote>
    # 查看指定远程版本库信息
    
    git pull <remote> <branch>
    # 下载代码及快速合并
    

     


8.Git分支管制

— PS.部分了 —


6.1. 生改成新的版本库

  1. 新建空目录
  2. 登该目录—单击右键—选择Git Bash Here
  3. 弹出git的命令行工具
  4. 初始化该目录为本仓库,键入 git init
  5. 显示 Initialized empty Git repository in xxxxxx
  6. ls -a 查看该目录下出现.git的藏身目录,即版本库
  7. 初始化完成
3.1 文件称艺术

昔日的软件开发过程,代码管理为手动以及邮件等花样,文件命名暨保存在问题

如果图 : 毕业论文版本

6.7. 删除

git rm index.php
# 删除index.php文件
git rm --cached index.php
# 将index.php文件移出缓存区,但不删除( -r * 递归目录)
git rm -f 1.html
# 将缓存区中的1.html文件移出并删除

 


7.2. 推送分支代码

得到远端版本库后,可以当地面本正常的手续编辑 :
新建或转移文件–>添加交缓存区–>提交到版本库

此时,要惦记以本地版本库发给远端,只有commit提交是不够的.
尚亟需下面的操作 :

git push <remote> <branch>
# 上传代码及快速合并

 

实行以上代码,会有回报错 : 无法直接推送至远端的主分支

这儿,可以曲线救国,推送自己之支行到远端即可 :

git push origin master:dev

 

这时候,推送成功!


5.1 安装

Linux安装

仲上制包(在线)
yum -y install git //RedHat系列
apt-get git install //Debian系列
源码包(官网下载)

Windows安装

Git在Windows使用模拟条件msysgit
下载地址:
https://git-for-windows.github.io/
顾:如果想叫windows作为git服务器则要搭建ssh服务。


准学科使用windows版本来做示范:

设置步骤:

1.挑安装路径

2.选创建图标,选择安装Git Bash和Git GUI

3.摘创建开始菜单

4.增选:use git and optional unix tools from the windows command
prompt(红字提示)

5.选择: windows-style

6.选择 : use mintty 默认终端

7.选择 : 系统文件缓存 和 git的管理器(需要.net v4.5.1)

8.点击 Install 安装

9.设置好,选择运行git bash工具


8.3. 集合分支

而拿B分支合并及A分支里
呼吁切换到A分支内,合并B分支的操作以A分支内进行

git merge 分支名
# 合并分支到当前分支 

 

4.科普版本控制系统

图 : 版本管理器的发展史

这张图上分为了季个时期 :

● 史前时:1982年的RCS。现在而或还能以Unix的通告包中找到它们。


古典时期:1990年底CVS自身弱点已经过时;1985年之PVCS、1992年之clearcase(费用高昂、功能复杂沿用至今);微软VVS反人类;Perforace(广泛,谷歌内部尽深代码管理器)


中世纪时:SVN解决了CVS的问题,集中式领域上。AccuRev(支持分支合并为森企业拜托cvs和clearcase)。


文艺复兴:BitKeeper(SUN公司大量利用),2002年Linux内核使用BitKeeper,2005年闭源时有人计算破解BitKeeper,于是起了Git。

5.Git底安装 和 基本配置

7. Git多人口搭档