新手向葡京在线开户–git版本控制器

      
前边我们上学了什么是线程,线程之间的共同,使用线程池。使用线程池可以削减我们大量长时间操作的竞相线程所用的操作系统资源。

Git 版本控制器

(本文档由XDL助教黄超,使用马克Down构建而成,转载请讲明出处)

        
本示例是从任务中拿到结果值。大家通过不同的履行结果来彰显在线程池中施行与在主线程中施行的不同之处。

8.Git分支管制

  接上文 多线程编程学习笔记——线程同步(三)

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获取

 


2.程序运行结果如下图。

6.7. 删除

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

 


二、   使用任务执行基本的操作

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
# 将远端库获取本地但不合并

 

       
下边的示范,我们使用task构造函数创制了五个任务。我们传入了一个lambda表明式做为操作任务。然后选用start启动任务。

8.5. 分层管理策略

葡京在线开户 1


       
接着,我们利用task.Run和task.startNew方法来运作六个任务。与使用task构造函数不同之处,在于这六个被成立的天职会即时施行。所以无需显式地调用
这些任务的Start方法。从task1到task4所有任务都是放在线程池中施行的,多次推行,可以窥见执行顺序是不平等的。

8.2. 创办分支/删除分支

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

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

 

 2.运作结果如下图。我把程序运行了五遍。请自行查看不同之处。

3.2 集中式

包括库和工作区两局部:工作区编码,再上传至库的措施形成四人搭档。
题材:工作机与库机需要联网才能控制版本,传输速度较慢。
葡京在线开户 2

       
一个任务(Task)可以透过多种方法和其余职责组合起来使用。例如,可以而且开启三个任务,等待所有任务完成,再起一个任务进展操作。一个职责可以有两个其他职责组成,这个任务也足以依次拥有自己的子任务。

3.1 文件名艺术

以往的软件开发过程,代码管理以手动和邮件等形式,文件命名及保存存在问题

如图 : 毕业杂谈版本
葡京在线开户 3

       
然后我们运行了task1,使用start方法启动任务并等候结果。那么些职责会被放在线程池中运作,而且主线程会等待,直到任务完毕并重临结果。

Git问世

Git的率先个版本是Linux之父Linus
Torvalds亲手操刀设计和促成的(两周内用C写完),Linus不仅仅给出一个本来设计,并在向世人介绍Git时一目领会批评了CVS和SVN等,Git消除了分层和统一的恐怖。很多巨型开源项目由SVN迁移至Git。

二〇〇八年www.github.com也变成世界最大的SCM系统(软件配置管理),它采取的就是Git版本库的技术.从此Git成为版本控制系统的主流。

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


 接上文 多线程编程学习笔记——线程池(三)

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.摘取设置路径
葡京在线开户 4
2.增选创立图标,接纳设置Git Bash和Git GUI
葡京在线开户 5

3.挑选创造起先菜单
葡京在线开户 6
4.精选:use git and optional unix tools from the windows command
prompt(红字提醒)
葡京在线开户 7

5.选择: windows-style
葡京在线开户 8
6.拔取 : use mintty 默认终端
葡京在线开户 9

7.采取 : 系统文件缓存 和 git的管理器(需要.net v4.5.1)
葡京在线开户 10
8.点击 Install 安装
葡京在线开户 11
9.设置到位,采纳运行git bash工具


 葡京在线开户 12

4.广大版本控制系统

图 : 版本管理器的发展史

葡京在线开户 13

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

● 史前一代:1982年的RCS。现在您恐怕仍是可以在Unix的发布包中找到它。


古典时期:1990年的CVS自身弱点已经不合时宜;1985年的PVCS、1992年的clearcase(费用高昂、效率复杂沿用至今);微软VVS反人类;Perforace(广泛,Google里面最大代码管理器)


中世纪一代:SVN解决了CVS的题目,集中式领域王者。AccuRev(帮助分支合并让无数铺面拜托cvs和clearcase)。


文艺复兴:BitKeeper(SUN集团大量拔取),2002年Linux内核使用BitKeeper,二〇〇五年闭源时有人总结破解BitKeeper,于是应运而生了Git。

接上文 多线程编程学习笔记——线程池(二)

6.2.添加文(加文(Gavin))件到版本库

  1. 新建文件 1.txt

  2. 翻开当前版本状态

    git status     #查看当前版本状态
    

     

  3. 红字提醒有文件未跟踪(未参与版本控制)

  4. 在工具内输入以下,添加文(加文(Gavin))书至版本库:

    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. 从那之后最简便易行的增长文件到版本库已做到


 

— PS部分: Git 实现原理 —

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

葡京在线开户 14

版本库包括:暂存区(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到缓存区,再度提交即可

  1. 代码如下:

5.Git的安装 和 基本配备

     

3.2 分布式

每台微机都有工作区和库自己说了算版本,数据更是安全,有逻辑上的中坚。
葡京在线开户 15


 接上文 多线程编程学习笔记——基础(二)

 

 接上文 多线程编程学习笔记——线程同步(一)

1.什么是Git

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

       
Task3运转task1的法子,不过这次没有阻塞主线程,只是在职责到位往日循环打印出任务状态。

6. Git常用操作

接上文
多线程编程学习笔记——线程池(一)

6.6. 撤销

目标:将尚未提交至版本库的改动撤回。

  • 处境一 : 文件修改后并未添加至缓存区

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

     

  • 动静二 : 文件修改已添加至缓存区

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

     


 接上文 多线程编程学习笔记——基础(三)

6.1. 生成新的版本库

  1. 新建空目录
  2. 进入该目录—单击右键—选拔Git Bash Here
  3. 弹出git的命令行工具
  4. 初叶化该目录为版本仓库,键入 git init
  5. 显示 Initialized empty Git repository in xxxxxx
  6. ls -a 查看该目录下出现.git的躲藏目录,即版本库
  7. 起初化完成
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks; 

namespace ThreadTPLDemo
{

    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Task 基本操作 ————");
            TaskOper("----主线程Task运行");

           Task<string> task1 =CreateTask("Task1");
            task1.Start();
            string result = task1.Result;
            Console.WriteLine(" 运行结果——{0}", result); 

            Task<string> task2 = CreateTask("Task2");
            task2.RunSynchronously();
            result = task1.Result;
            Console.WriteLine(" 运行结果——{0}", result); 

            Task<string> task3 = CreateTask("Task3");
            task3.Start();
          while(!task3.IsCompleted)
            {
                Console.WriteLine(" 状态——{0}", task3.Status);
                Thread.Sleep(500);
            }

            Console.WriteLine(" ——状态—{0}", task3.Status);
            result = task3.Result;
            Console.WriteLine(" 运行结果——{0}", result);           

            Console.ReadKey();
        }
        private static string TaskOper(string  name)
        {         

            Console.WriteLine("Task 线程 ID:{0} 上,是不是线程池中的线程:{1},名称: {2}",
            Thread.CurrentThread.ManagedThreadId,Thread.CurrentThread.IsThreadPoolThread, name);
            Thread.Sleep(2000);
            return string.Format("线程ID:{0},名称:{1}", Thread.CurrentThread.ManagedThreadId,name);
        }
        static Task<string> CreateTask(string name)
        {
            return new Task<string>(() => TaskOper(name));

        }
    }
}

7. Git四人合作

接上文 多线程编程学习笔记——基础(一)

2.怎么着是版本控制系统?

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

版本控制是一种软件工程技术,能在软件开发的经过中,确保由不同人所编写的同一代码文件案都取得同步.
版本控制能使项目标设计者,将项目苏醒到前边任意的意况,那种拔取权在统筹过程中特意首要.
辩驳上独具的音信记录都得以添加版本控制:利用版本控制来追踪、维护源码、文件以及配置文件等等的转移


 接上文 多线程编程学习笔记——线程同步(二)

— PS.部分截止 —


         
Task5,由于我们标记为了长日子运作,所以是一个单独的线程,不是线程池中的线程来运作的。

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>
    # 下载代码及快速合并
    

     


         以下示例,我们使用.Net
Framework 4.5将来版本。

6.5. 作为日志

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

 


       
Task2与task1相似,Task2通过RunSynchronously()方法运行的。那么些职责运行在主线程中,这一个任务的输出与TaskOper方法输出结果同样。这就是task的优势,可以应用task对TaskOper方法举行优化,可以避免使用线程池来执行一些执行时间相当短的操作。

8.3. 合并分支

要将B分支合并到A分支里
请切换来A分支内,合并B分支的操作在A分支内举办

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

 

 

9. 运用代码托管体系

市面上著名的Git托管系统 :

以下以开源中国为例,来学习应用

一、   创设任务

8.1. 查看版本库分支

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

 

       在net framework
4.0中微软又提供了一个新的异步操作的服从,叫做任务并行库(TPL)。任务并行库的主导是天职(task)。一个任务代表了一个异步操作,譔操作能够透过多种措施运行,可以拔取或不行使独立的线程。

3.版本决定发展史

 

7.2. 推送分支代码

赢得远端版本库后,可以在当地按正常的手续编辑 :
新建或改变文件–>添加至缓存区–>提交到版本库

此刻,要想将地面版本库发给远端,只有commit提交是不够的.
还亟需下面的操作 :

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

 

施行以上代码,会有报错 : 不可能直接推送到远端的主分支

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

git push origin master:dev

 

此时,推送成功!


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks; 

namespace ThreadTPLDemo
{
    class Program
    {
        static void Main(string[] args)
        {

            Console.WriteLine("Task 运行示例 ————{0}",DateTime.Now);

           var task1 = new Task(() => TaskOper("Task1"));
            var task2 = new Task(() => TaskOper("Task2"));
            task1.Start();
            task2.Start();           

            Task.Factory.StartNew(() => TaskOper("Task 3"));
Task.Run(() => TaskOper("Task 4")); 

            //长时间运行
            Task.Factory.StartNew(() => TaskOper("Task 5"),TaskCreationOptions.LongRunning);
                      Thread.Sleep(1000);
            Console.ReadKey();
        }
        private static void TaskOper(string  name)
        {           

            Console.WriteLine("Task 运行在 线程 ID:{0} 上,这个线程是不是线程池中的线程:{1},名称: {2}",            Thread.CurrentThread.ManagedThreadId,Thread.CurrentThread.IsThreadPoolThread, name); 

        }
    }
}

8.4. 解决统一争论

多分支修改同一文件,合并或者出现争持。争辩部分用<<<===>>>表示

葡京在线开户 16

解决方法:
先手动修改争辩部分,再度提交即可。


 1. 代码如下:

5.2 配置

无论Linux仍旧Windows,安装到位后都要起首化

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

 

中括号内的参数:

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

 

葡京在线开户 17

6.3.翻看文件修改境况相关

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

 

修改文件测试以下 :

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

 

Git日志,分析日志构成 :

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

 


        
C#5.0及今后的本子都曾经嵌入了对TPL的扶助,允许大家应用await与async关键字展开任务履行。

       
首先直接运行TaskOper方法,依据程序运行结果,我们得以清楚这么些措施是被一块实施的。