- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我在一个由 4 名 .Net 开发人员组成的小组中工作。我们很少同时处理同一个项目,但这种情况时有发生。我们使用 TFS 进行源代码控制。我最近的示例是我昨晚刚刚投入生产的一个项目,其中包括 2 个 WCF 服务和一个 Web 应用程序前端。我在一个名为“prod”的分支工作,因为该应用程序是全新的并且从未见过。现在该项目已经上线,我需要从 prod 分支分支以获取功能、错误等...
那么最好的方法是什么?
我是否简单地创建一个新分支并将旧分支存档并且不再使用它?
当我想部署到生产环境时,我是否要分支然后将我的分支更改合并回 prod 分支?
文件和程序集版本呢?它们目前为 1.0.0.0。他们什么时候改变,为什么?如果我修复了一个小错误,哪个数字会发生变化?如果我添加一项功能,哪个数字会发生变化?
我正在寻找的是您发现的有效管理源代码控制的最佳方式。我工作过的大多数地方似乎总是在途中或其他地方与源代码控制系统发生冲突,我只是想找出您发现的最有效的方法。
最佳答案
最好有一个单独的分支来支持每个已发布的版本,另一个分支用于继续开发。这样一来,无论您在主分支上开发的新功能如何,您始终可以为旧版本生成错误修复版本。
从长远来看,最好将主分支作为你的开发分支,并为每个特定的版本创建一个单独的支持分支;这使您的分支路径变短。 (我从事过一个项目,其中实际工作分支的路径类似于 main/release_1.0/release_1.1/release_1.5/release_2.0/release_2.1
...不想走那条路 :-)
当然,您需要定期将在支持分支上所做的任何修复合并回主分支 - 至少在创建下一个版本之前。我的经验是,绝对不建议将合并留到最后一分钟——合并越晚,两个分支之间的差异就越大,因此遇到麻烦的机会就越大。如果合并更改的复杂性超过某个阈值,自动合并工具就会放弃……并且手动合并并不好玩。
在很大程度上,版本控制可能是个人偏好的问题。在小型项目中,您可能对 major.minor 版本方案感到满意,在大型项目中,您可能还希望使用补丁和/或构建版本号进行更精细的控制。
你需要制定一个版本策略然后坚持下去。例如。如果您使用 major.minor 版本方案,请为错误修复版本增加次要版本,为新功能版本增加主要版本。
关于c# - 开发人员如何使用源代码控制,我试图找到在小型开发环境中进行源代码控制的最有效方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2833900/
我需要一些说明。我可以直接写入 /dev/port 以直接访问并行端口并且它工作正常(我可以打开插入端口连接器的 LED)。但是,我想我可以用 /dev/mem 做同样的事情? (http://tld
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我使用 Visual C++ 和 Win32 API 学习了 Windows 编程。如今,似乎大多数应用程序都是使用 C# 在 .NET 中开发的。我知道大多数时候 native 代码和托管代码之间没
请耐心等待。我正在制作一个 java 控制台,类似于此处找到的 DragonConsole https://code.google.com/p/dragonconsole/ 。一切都按计划进行,但我想
关闭。这个问题需要更多 focused .它目前不接受答案。 想要改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭5年前。 Improve this que
Django 的开发服务器表现得很奇怪。访问它的浏览器在加载时卡住,任何退出它的尝试都不起作用。当我点击 control c看似相当,但实际上仍在运行。让它退出的唯一方法是重新启动我的电脑,这很令人沮
我正在使用 Flash Develop,并且创建了一个 ActionScript 3.0 项目。它启动并读取一个 xml 文件,其中包含图像的 url。我已将 url 保留在与 swf 相同的文件夹中
是否可以根据其 website 上提供的规范开发 AUTOSAR BSW 堆栈(例如用于 CAN 通信)?不购买任何昂贵的供应商工具?可以遵循哪些步骤?我被要求探索这种可能性。 最佳答案 是和否。工具
有人知道如何用音频文件的内容覆盖 iPhone 麦克风吗? 想象一个场景,您正在通话,并且想要播放一些简短的音频让其他人听到。 因此,有必要将麦克风(硬件)置于保持状态,并使用委托(delegate)
我遇到了这个问题,我的应用程序出现 EXC_BAD_ACCESS 错误并卡住/停止。我使用模拟器的“向左旋转”和“向右旋转”选项来模拟方向变化行为。导致此错误的可能原因有哪些?由于我没有获得有关错误的
我有超过 1 台 Mac,我想在所有这些 Mac 上进行开发。我知道我需要在每台机器上同步我的手机,但这是我遇到的最小的问题。看起来我无法在手机上运行应用程序,除了在其中之一上开发的应用程序。 是否有
在手机上测试时,我的应用程序在特定点崩溃。控制台显示此消息 Tue Jan 27 15:47:14 unknown SpringBoard[22] : Application com.myprof.
我有一个案例,我从服务器获取信息。我的应用程序有一个选项卡栏和导航按钮。我希望应用程序显示进度指示器并禁用所有其他控件,以便用户在从服务器提取数据时无法跳转。我怎样才能实现这个目标? 我想到的一种方法
有时,当我尝试“构建”/编译下载的源代码时,我会收到以下警告: ld: warning: directory '/Volumes/Skiiing2/CD/ViewBased/Unknown Path/
我无法在 Apple 文档中找到关于开发和分发配置之间差异的明确解释。我目前正在使用开发配置在我的 iPhone 上进行开发和测试。我打算将该应用程序分发到我的 Beta 测试中,我想知道: 我需要使
我在使用 SharePoint 时遇到的最大挑战之一是它不能很好地适应典型的项目环境,其中至少包含开发和生产环境。我遇到的最多的问题是内容和列表是如此紧密地耦合在一起,以至于如果不在生产环境中执行内容
我失败了fist step让 Eclipse(对我来说是全新的)为 ARM 开发做好准备。 我在 Windows 10 中安装了 Eclipse。我想我应该安装 xpm,但我不知道在哪里输入此命令:
首先,我告诉你-我是编码新手 我正在使用vs代码来学习c++,它不会产生像dev c++或codeblocks这样的调试器。我看了一些视频,其中我们必须编辑json文件,这对于初学者来说非常复杂。有人
我失败了fist step让 Eclipse(对我来说是全新的)为 ARM 开发做好准备。 我在 Windows 10 中安装了 Eclipse。我想我应该安装 xpm,但我不知道在哪里输入此命令:
我开发了一个 Ionic 应用程序(iOS 和 Android 的混合)。我有 Xcode 8.3.3 并购买了一年的 Apple Developer Program 订阅。 我不想测试我的应用并将其
我是一名优秀的程序员,十分优秀!