是否有什么指导方针或标准的最佳实践,如何在业余时间开发一个有趣的软件,但仍然会被一些人使用?我认为有必要对这样的软件进行版本化,这样你就可以知道第一版所谈论的内容(例如修复错误、支持等等)。
但是我从哪里开始版本控制呢?0.0.0吗?还是0.0 ?然后如何增加这些数字呢?主要版本。小改变?任何版本控制系统都不应该是另一个版本吗?或者这仅仅是用于生产方式的版本?
是否有什么指导方针或标准的最佳实践,如何在业余时间开发一个有趣的软件,但仍然会被一些人使用?我认为有必要对这样的软件进行版本化,这样你就可以知道第一版所谈论的内容(例如修复错误、支持等等)。
但是我从哪里开始版本控制呢?0.0.0吗?还是0.0 ?然后如何增加这些数字呢?主要版本。小改变?任何版本控制系统都不应该是另一个版本吗?或者这仅仅是用于生产方式的版本?
当前回答
还有日期版本控制方案,例如:YYYY。嗯,yy。嗯,yyyymmdd
它的信息量很大,因为第一眼就能给人关于发布日期的印象。但我更喜欢x.y.z方案,因为我总是想知道产品在其生命周期中的确切位置(主要。次要。发布)
其他回答
我从最低(非热修复)段开始版本控制。我不限制这个部分为10个。除非您正在跟踪构建,否则您只需要决定何时应用增量。如果你有一个QA阶段,那么你可能会应用一个增量到最低段,然后当它通过QA并发布时,再往上应用一个增量到下一个段。将最上面的部分留给主要的行为/UI更改。
如果你像我一样,你会让它成为一种混合的方法,以匹配你的软件进程的速度。
我认为最被接受的模式是a.b.c.或a.b.c.d,特别是当你将QA/合规混合在一起时。我在约会期间受到了太多的抨击,成为了版本的常规部分,所以我放弃了主流。
我不跟踪构建,所以我喜欢使用a.b.c模式,除非涉及热修复。当我必须应用热修复程序时,我应用参数d作为日期和时间。我采用d作为时间参数,因为在生产中,当事情真正爆发时,一天中总有好几次的可能性。我只应用d段(YYYYMMDDHHNN)当我为一个生产固定发散。
我个人并不反对va.b revc的软件方案,其中c是YYYYMMDDHHMM或YYYYMMDD。
话虽如此。如果你能找到一个工具进行配置并使用它来运行,你就不用再为版本控制的意见方面而头疼了,你只需说“使用这个工具”……因为开发过程中的每个人通常都非常顺从。
还有日期版本控制方案,例如:YYYY。嗯,yy。嗯,yyyymmdd
它的信息量很大,因为第一眼就能给人关于发布日期的印象。但我更喜欢x.y.z方案,因为我总是想知道产品在其生命周期中的确切位置(主要。次要。发布)
a.b.c.方法的另一个例子是Eclipse Bundle Versioning。Eclipse包有第四个部分:
在Eclipse中,版本号由四(4)段组成:3个整数和一个分别名为major.minor.service.qualifier的字符串。每个片段都抓住了不同的意图: 主段表示API的破坏 次要部分表示“外部可见”的更改 服务段表示bug修复和开发流的更改 限定符段指示特定的构建
我们遵循abc方法:
如果应用程序中发生了一些重大变化,则增加“a”。比如我们把。net 1.1应用程序升级到。net 3.5
如果有一些小的变化,如任何新的CR或增强,则增加'b'。
如果在代码中修复了一些缺陷,则增加'c'。
我们用a.b.c.d
A -主要(在交付给客户端时增加) B -小调(交付客户时增加) C -修订(在内部版本上增加) D - build(随巡航控制增加)