当前位置: 首页 > 编程日记 > 正文

【阶段小结】协同开发——这学期的Git使用小结

【阶段小结】协同开发——这学期的Git使用小结

  • 一、Git简介
    • 1. Git简单介绍
    • 2. Git工作流程以及各个区域
    • 3. Git文件状态变化
  • 二、Git安装&Git基本配置
  • 三、个人踩坑
    • 1. xcode project“抽风式”问题
    • 2. 如何拯救git仓库

一、Git简介

1. Git简单介绍

Git是一个分布式版本控制软件,最初由Linus Torvalds创作,于2005年以GPL发布。最初目的是为更好地管理Linux内核开发而设计。

2. Git工作流程以及各个区域

img

  • Workspace:工作区
  • Staging/Index:暂存区
  • Local Repository:本地仓库(可修改)
  • /refs/remotes:远程仓库的引用(不可修改)
  • Remote:远程仓库

3. Git文件状态变化

img

二、Git安装&Git基本配置

由于网上教程很详尽了,此处省略简单的安装与配置,总的来说只需要配置好相应的git平台的账号配置即可。

就个人而言,我目前使用的git平台主要是github与gitee,主要是搭配git+vscode来使用,个人感觉开发效率极高。

三、个人踩坑

Git是我们“程序猿”常用的协同开发工具,由于本学期修了很多开发相关的课程,频繁地使用了Git。与之前简单的git push/pull,我也遇到了很多的新问题。

1. xcode project“抽风式”问题

对于简洁的C/C++/Golang等项目,使用git往往不需要太多配置。而对于基于objective-c的xcode project开发而言,如果不谨慎地设置gitignore文件,简直就会让协同开发效率事倍功半。

比如,我们很容易就很会出现由于新增了项目文件,在merge项目之后导致项目不能运行的情况(连编译都无法通过),这是由于xcode project有一大堆编译相关的文件,在merge之后往往会出现各种冲突,另外也有许多不必要的文件也被上传上去,导致项目仓库很臃肿,因此一个好的gitignore文件是很有必要的。

在这里我提供一个gitignore文件,虽然还不是很完善,但也比网上多数的要全面,仅供参考【其中Group8是项目名】:

.DS_Store
*/.DS_Store
*/**/.DS_Store
code/Group8/Pods/
code/Group8/Podfile.lock
*/UserInterfaceState.xcuserstate
code/Group8/Group8/.DS_Store

2. 如何拯救git仓库

在协同开发过程中,虽然我们可以建立个人分支,防止污染主分支,但是也有可能会出现一不小心把远程仓库弄“烂”或者向把远程仓库强制替换的情况。

这里我们主要聚焦于两个问题,即本地仓库强制替换为远程仓库与远程仓库强制替换为本地仓库,就个人而言,这两个操作足以避免我一开始减了几个个人分支的尴尬局面。

假设本地分支的仓库为henry,远程仓库为origin/henry

①本地仓库强制替换为远程仓库

git log #找到commitid
git reset --hard commitid #回滚本地仓库
git push origin henry --force #本地仓库强制替换为远程仓库

②远程仓库强制替换为本地仓库

git reset --hard origin/henry

相关文章:

PHP函数printf()、sprintf()的用法

printf()函数优点在于可以格式化输出 格式: %[padding_character][-][width][.precision]type 所有的转换说明都是以%开始,如果想打印一个%符号,必须用%% ; 参数“padding_character”是可选,它将被用来填充变量直至所指定的宽度,该参数的作用…

20150411--Dede二次开发-01

20150411--Dede二次开发-01 目录 一、目前市场流行的电子商城系统 1 二、ecshop的介绍 1 三、安装 2 四、echsop 的目录结构 5 五、分析ecshop里面程序的架构 5 六、小试牛刀把面包屑导航改成两个大于号 6 1、根据php页面找出该页面对应的模板。 6 2、找到category.dwt模板文件…

修改cpu型号重启不变_猫头鹰展示D系列新款140毫米CPU散热器:更大散热片,能压400瓦...

猫头鹰一直以超强的CPU风冷散热器在电脑配件市场闻名遐迩,在台北电脑展期间,除了展出了概念性的无风扇CPU散热器,还宣布了发布D系列新款CPU散热器的计划。新的未命名的散热器相比与目前的NH-D15和NH-D15S型号要多一根热管,性能进一…

管理虚拟机的艺术——有备无患

随心前言:求求你们多多给虚拟机做一下备份~~ 超前预告:下一次分享一下linux/window to go的小玩意(把系统安装到U盘,即插即用) 接下来的博客尝试一下用随笔的形式,来写写自己感兴趣的一些玩意,比…

coreseek最大检索数只有1000的问题!

在 测试中发现,综艺视频只能看33页,每页10条,始终不得其解。经仔细分析,是csft.conf中的配置,下面修改说明如下:先将csft.conf中的searchd部分,将1000默认值改为10000max_matches 10000然后在调…

iframe怎么用_怎么样减少无效URL的爬行和索引

少年老成的云晨守望同学(题外话:少年老成是好事哈。我20多岁时人家说我像40岁,我40多岁时好多人说我像30多,男人20到50岁可以做到基本一个样子)在网络营销实战密码网站贴了个帖子:《透过京东商城看国内一线B2C网站SEO通病》。建议…

502 Server dropped connection

在本地电脑上开启了,全局VPN代理后,出现 502 报错。 502 Server dropped connection The following error occurred while trying to access http://localhost/invo/:502 Server dropped connection. 出现这种情况的原因是,vpn 链接挂了&…

【OpenCV】在Linux上使用OpenCvSharp

OpenCvSharp是一个OpenCV的 .Net wrapper,应用最新的OpenCV库开发,使用习惯比EmguCV更接近原始的OpenCV,该库采用LGPL发行,对商业应用友好。

DNS轮询解析是什么?

在其最简单的实现中,轮回DNS的工作方式是,不仅用一个潜在的IP地址来响应DNS请求,而且用一个潜在的IP地址列表来响应承载相同服务的几个服务器。传统的负载均衡技术通常需要专门的硬件或软件,但DNS轮询解析是一种负载分配、负载平衡或容错技术,通过管理域名系统(DNS)对来自客户计算机的地址请求的响应,按照适当的统计模型,提供多个冗余的互联网协议服务主机,将流量分散到多个服务器上。因此,虽然轮询DNS是一种简单有效的负载平衡方法,但它也存在一些限制和潜在的问题,需要根据实际情况进行选择和使用。

自建WIN10 FTP无法访问的解决方法

由于博主使用的是校园网,具体NAS方案比较复杂,主体上是用KodCloudWin10自带FTP,最近发现好像自带的FTP搭建不了。 废话不多说,说说解决方案: ①首先看看防火墙设置,用同一局域网下的主机ping一下测试是否能…

weiss数据结构和算法书的使用说明

《数据结构与算法分析 C语言描述》Mark Allen Weiss著,冯舜玺译,机械工业出版社。Weiss教授的经典教材三部曲之一,其中的C语言描述版本,也就是本书,被称为20世纪最重要的30本计算机教材之一。Mark Allen Weiss&#xf…

Bootstrap 栅格系统 理解与总结

Bootstrap 栅格系统 学习总结 Bootstrap框架是如今最流行的前端框架之一,Bootstrap功能强大,简单易学,很符合实际应用场景。 只是Bootstrap的内容较多,新手往往不能很快的熟练运用Bootstrap。 这里,我就对Bootstrap中非…

java抛出自定义异常_10 个深恶痛绝的 Java 异常。。

异常是 Java 程序中经常遇到的问题,我想每一个 Java 程序员都讨厌异常,一 个异常就是一个 BUG,就要花很多时间来定位异常问题。什么是异常及异常的分类请看这篇文章:一张图搞清楚 Java 异常机制。今天,栈长来列一下 Ja…

mac删除键很慢

关闭辅助功能-慢速键 重复延迟、等待调到最低

不相交集类以及应用迷宫生成

简单介绍: 考虑一个迷宫的生成,一个简单算法就是从各处的墙壁开始(除入口和出口之外)。此时,不断地随机选择一面墙,如果被该墙分割的单元彼此不联通,那么就把这面墙拆掉。重复这个过程直到开始单…

Ajax 完整教程

转载:http://www.cnblogs.com/Garden-blog/archive/2011/03/11/1981778.html Ajax 完整教程第 1 页 Ajax 简介Ajax 由 HTML、JavaScript™ 技术、DHTML 和 DOM 组成,这一杰出的方法可以将笨拙的 Web 界面转化成交互性的 Ajax 应用程序。本文的作者是一位…

python嵩天课后思考题_Python语言程序设计基础(第二版)嵩天等课后习题答案

第一次博文 Time:2018年04月28日 星期六 11:37二次补充 2018年05月02日第一章 程序设计基本方法 P29# 1.1字符串的拼接str1 input("请输入一个人的名字:")str2 input("请输入一个地点:")print("世界这么大&#x…

mac OneNote恢复历史记录

由于mac OneNote是个废物,因此还是得通过网页版OneNote或者win版OneNote来操作 网页端OneNote-对应笔记本页面 然后复制过去就可以恢复了

【C#公共帮助类】10年代码,最全的系统帮助类

这个帮助类主要包含&#xff1a;对象转换处理 、分割字符串、截取字符串、删除最后结尾的一个逗号、 删除最后结尾的指定字符后的字符、 生成指定长度的字符串、 生成日期随机码、 生成随机字母或数、字 截取字符长度、 对象<-->JSON 4.0使用、 对象<-->JSON 2.0使…

三十之惑–面霸的八月(第一部分)

三十之惑 –面霸的八月 题记&#xff1a; 三十几岁了&#xff0c;从sina大学肄业后&#xff0c;在外面漂泊&#xff0c;不好不坏。 从好的角度讲&#xff0c;这几年自己的技术没有减退&#xff0c;偶尔也还能够略有深入&#xff0c;同时能够更多的接触到产品、运营、甚至营销&a…

python小工具封装_python接口自动化(二)——封装需要用到的工具类

封装需要用的工具类&#xff1a;1、封装读取Excel的工具类&#xff0c;这里选用的是pandas&#xff1a;importpandas as pdpath ‘test.xlsx‘sheet_name ‘test_data‘classwith_excel:#构造函数&#xff0c;调用类时就运行def __init__(self, pathNone, sheet_nameNone):if p…

三十之惑–面霸的八月(第二部分)

书接上回&#xff0c;今天叙述小米的面试经历。 这里可能有一些技术理解和技术方案&#xff0c;欢迎讨论。另昨天共计收入7笔共95元&#xff0c;够我喝几杯咖啡了&#xff0c;谢谢所有捐钱的朋友。 如果你心疼我码字辛苦&#xff0c;有钱朋友钱场&#xff0c;没钱的请拉朋友来捧…

Curator Cache

1.Curator Cache 与原生ZooKeeper Wacher区别 原生的ZooKeeper Wacher是一次性的&#xff1a;一个Wacher一旦触发就会被移出&#xff0c;如果你想要反复使用Wacher&#xff0c;就要在Wacher被移除后重新注册&#xff0c;使用起来很麻烦。使用Curator Cache 可以反复使用Wacher了…

程序可以在硬件之间发送吗_你知道硬件、软件工程师之间,还有一个固件工程师吗?...

软件跟硬件之间的界限已经越来越模糊了&#xff0c;那么处于这个灰色地带的&#xff0c;就是固件了。这就分成三类工作者。1、软件工程师一般指做图形界面的程序员&#xff0c;工作内容就是写C、JAVA、Web等。2、硬件工程师当然是指玩电路板的&#xff0c;工作内容就是画原理图…

悲催的跨平台文献管理能力

1.古老的TCP交互 邮箱、FTP、硬盘 2.用现成软件Zotero 免费、跨平台、导入后在Win福昕注释可实时同步mac看看 人生苦短&#xff0c;我用Zotero。。

Mastering Algorithms with C中文版附带源码说明

Mastering Algorithm with C是一本非常经典和独具个性的算法书,主要是从程序员的角度,对算法领域的基本内容,通过C语言进行源码实现,其附带的源码非常详细,对初接触这个领域的程序员很有参考价值.我特地将该书源码的使用方法做了笔记,放在这样,以便日后参考. 下面是该书的封面…

仿qq左滑删除listview_Java基于Swing和Netty仿QQ界面聊天小项目

点击上方 好好学java &#xff0c;选择 星标 公众号重磅资讯、干货&#xff0c;第一时间送达今日推荐&#xff1a;硬刚一周&#xff0c;3W字总结&#xff0c;一年的经验告诉你如何准备校招&#xff01;个人原创100W访问量博客&#xff1a;点击前往&#xff0c;查看更多来源&…

[BZOJ1602] [Usaco2008 Oct] 牧场行走 (LCA)

Description N头牛&#xff08;2<n<1000&#xff09;别人被标记为1到n&#xff0c;在同样被标记1到n的n块土地上吃草&#xff0c;第i头牛在第i块牧场吃草。 这n块土地被n-1条边连接。 奶牛可以在边上行走&#xff0c;第i条边连接第Ai&#xff0c;Bi块牧场&#xff0c;第i…

大数据中用到的新的数据类型bigint、decimal、smallint、tinyint

在对比oracle数据库和大数据库的时候&#xff0c;发现了几个用以存放数字的新的类型bigint、decimal、smallint、tinyint&#xff0c;为了对比之间的不同&#xff0c;我进行了统计 bigint 可以精确的表示从-263到263-1(即从-9,223,372,036,854,775,808到 9,223,372,036,854,77…

[综合面试] 计算机面试书籍与求职网站推荐

一、推荐书籍 计算机的好书挺多的&#xff0c;我买了也有四五十本&#xff0c;也花了不少钱&#xff0c;但是这些投资都是值的&#xff0c;好好看一下这些书&#xff0c;让自己找工作时的薪水涨个几千是没问题的。当然&#xff0c;也有些书是电子版的。我是c方向的&#xff0c;…