git核心分支

git的分支是十分的轻量级,git的新建分支,合并分支等操作几乎是瞬间完成。
1、Git 创建一个新的分支仅仅是创建一个新的分支指针。如:git branch testing 创建一个testing分支;会commit 对象上新建一个分支指针并指向当前commit
2、Git 是如何知道当前在哪个分支上工作的呢?有一个名为HEAD 的特别指针,运行git branch 命令,仅仅是建立了一个新的分支,但不会自动切换到这个分支中,所以当前我们仍然在master分支。
3、要切换到其他分支,执行git checkout 命令。我们现在转换到新建的testing 分支:git checkout testing,git仅仅是将HEAD指针指向了testing,几乎瞬间完成。
4、如果这时我们再次修改了文件,并提交(git commit ),仅仅是testing分支指向了最新commit ,而master仍指向在原来的commit
5、使用git checkout master切换回master分支。git做了两件事它把HEAD 指针移回到master 分支,并把工作目录中的文件换成了master 分支所指向的快照内容。
注意:在git中新的commit对象中的parent是指向着上一个commit。
6、在master分支我们修改文件再进行提交,这时项目提交历史产生了分叉。
Git 中的分支实际上仅是一个包含所指对象校验和(40 个字符长度SHA-1 字串)的文件,所以创建和销毁一个分支就变得非常廉价。新建一个分支就是向一个文件写入41 个字节(外加一个换行符)。
如果我们有需要我们可以完全再次checkout到testing分支去开发新的功能。我们可以在分支间随意切换,并且都是瞬间切换完成。这和之前大多数版本控制系统形成了鲜明对比,它们管理分支大多采取备份所有项目文件到特定目录的方式,所以根据项目文件数量和大小不同,可能花费的时间也会有相当大的差别,快则几秒,慢则数分钟。而Git 的实现与项目复杂度无关,它永远可以在几毫秒的时间内完成分支的创建和切换。每次提交时都记录了祖先信息(译注:即parent 对象),所以以后要合并分支时,寻找恰当的合并基础(译注:即共同祖先)的工作其实已经完成了一大半。

Git 中commit、tree、blob三个对象之间的关系

在现有的项目中查看Commit、tree、blob


进入到有git管理的项目所在的磁盘目录下:
执行git log查看版本提交历史:
每个commit都对应唯一的编号
来看上边执行到最后的冒号:这时该怎么退出再次进入书写git命令呢,  直接输一个 q 就可以了
查看就近commit具体的内容:
git cat-file -p 82cfe8
看到了这个commit中有个tree
接着看下这个tree的具体内容:
git cat-file -p 56c3567

对应磁盘中:
没显示的都是被忽略的文件
tree中又包括tree和blob
查看blob的具体内容,也就是上图中 .gitignore的内容
对应磁盘目录下该文件的内容是一模一样的
至此commit、tree、和blob三者之间的关系也就一目了然了。
1.commit存储一次提交的信息,包括所在的tree,parent是谁,以及提交的作者是谁等信息。
2.tag:标签,给重要的commit的一个别名。
3.tree:代表的是目录结构,或者简单理解为代表一个目录
4.blob:用来存储文件内容,或者说表示一个文件

总结
每一次commit对应一个tree,这个tree又记录了整个文档的目录结构,文件的每一次修改又会生成一个blob,blob信息记录在tree下面。

电脑总是弹出SohuNews.exe应用

弹出sohunews.exe应用程序错误的方法一:机智删除

  1、找到搜狗拼音输入法的安装目录,默认的安装目录在c盘的program files→sougoupinyin→7.0.0.9604(这个是版本号,可能不同)。
  2、在这个文件夹里可以发现一个叫sohunews.exe的东西,删掉它。
  3、为了防止它再次出现,新建一个文件夹,并命名为sohunews.exe。系统是不允许文件和文件夹重名的,所以这个东西就不会再出现。可以到回收站里试着还原一下那个文件,可以看到如图弹窗就成功了

弹出sohunews.exe应用程序错误的方法二:暴力卸载
  1、卸载搜狗拼音输入法,简单粗暴但很有效!换其他什么输入法都行。