jjzjj

.net - 改用VS10有什么经验?

coder 2023-11-14 原文

我们正在考虑将超大型产品升级到VS10。

我听说过很多关于VS10的好消息,并且对C++ 0x的新功能感到非常兴奋,但是在使用VS10时,我遇到了一种情况,其中有一个示例玩具应用程序崩溃了(在VS8中没有)。似乎有一个compiler bug in some C++0x features的情况。

在另一种情况下,我看到unorderd_map抛出bad_alloc异常,其中it doesn't do so in VS9

我们的产品由本地C++和.NET组成,是几百万行代码。有没有人有将类似项目迁移到VS10的经验?这个过程痛苦吗?此举是否造成了任何退步?

我正在寻找更多轶事证据,因为我在网上找到的所有评论都不错,而且与我的经验不符。

最佳答案

我们也有一个类似的大型项目。我没有运行代码行计数器,但我想很容易就会有一百万。大约有200个项目-大约140个c++项目,全部使用COM/DCOM和60多种.NET,这些项目使用Winforms/WPF/etc的各种组合。我们有很多COM互操作和PInvoke
我们以前使用的是VS2008 for C++/C#,目标是.NET Framework 3.5SP1,而现在已经迁移到VS2010,使用C++,目标是.NET 4。
总体印象:

  • 总体而言升级并不十分痛苦。它花了一天的时间才能启动并运行,然后又由另一对夫妇(分布在各个开发人员中)解决了其他尚待解决的问题
  • 我个人认为VS2010比2008年要好,但这并不是升级的主要内容。好处来自语言改进(C++ 0x和.NET/C#4)
  • 项目不向后兼容。您的整个团队都必须立即跳起来。
  • 它确实解决了一些令人讨厌的问题,例如添加引用对话框,以及它花了很长时间来使项目上的上下文菜单出现
  • IDE崩溃的次数比2008年少得多,但仍然每两天崩溃一次。
  • 新的VS2010附加组件非常简洁
  • “多监视器”支持并不多。您可以在IDE外部 float 许多单个代码窗口,但不能将它们停靠在一起。基本上,您会在主屏幕上看到标签,而在辅助屏幕上会看到很多 float 窗口,这毫无用处。
  • ClickOnce仍然很糟糕!
  • 您不必升级构建计算机。只需在上面安装VS2010并调整TFSBuildService配置,使其了解.NET 4

  • C++
  • 不要安装“电源命令”插件。使用C++项目时,它会破坏IDE。 (基本上,这会使IDE失去并每秒获得约100倍的焦点,这意味着您无法选择文本或正确使用键盘快捷键)
  • C++项目格式已从.vcproj更改为.vcxproj。 Visual Studio项目升级向导可以处理大多数事情,但是确实丢失了一些之前/之后的构建步骤,我们不得不手动将它们放回原处。
  • 您可以使用VS2010,但仍以VS2008 C++编译器为目标。出于谨慎考虑,我们最初是在迁移项目后执行此操作的。切换到VS2010编译器并没有什么大不了的,所以我们在一两天后就选择了它-我们从STL向我们抛出了一些断言,但是从技术上来讲这些事情都是错误的,因此我们只修复了它们。
  • 升级C++项目时遇到的主要问题是,项目依赖项现在存储在.vcxproj文件中,而不是存储在解决方案中。您知道如何右键单击项目,选择“依赖项”并在依赖项的方框中打勾吗?这仍然会影响VS2010中的构建,但是 MSBuild并没有注意。这意味着您的构建机器构建几乎肯定会中断,因为构建顺序将是错误的。您必须调出项目的属性页,选择“框架和引用”,然后在其中放置依赖项。
  • 这也意味着,如果您需要在.NET dll之前构建纯 native DLL(例如因为您PInvoke),则不能依靠构建顺序来工作!我们必须手动编辑.NET项目的.csproj文件,并在本地项目中添加“引用”。这会导致VS引发编译器警告,但这是使它按正确顺序构建事物的唯一方法
  • C++ 0x中的
  • auto是蜜蜂的膝盖。
  • VS2010 C++编译器花费的时间几乎与2008年相同。

  • 。净:
  • 升级C#项目是非事件。我们遇到的大多数问题是由于冲突造成的,在冲突中,我们自己手动回传了某些类(例如Tuple)并不得不删除回传。
  • .NET 4非常高兴地加载旧的.NET 3.5代码。我们的一位开发人员对整个Codeplex WPFToolkit进行了自定义 fork (不要问,叹气)。 Microsoft将此工具包折叠到4.0中的.NET核心中。我以为我们会有很多冲突,但是我们只是加载了 fork 的工具箱dll,一切都无缝运行。
  • 令人讨厌的异常(exception)是单元测试。您可以在2010年构建面向.NET框架v2、3或3.5的.NET应用程序,但是Visual Studio只能加载以.NET 4为目标的单元测试项目。 ,这意味着您没有多重定位。
  • 在WPF中修复非模糊文本非常好。为什么他们用坏了的文字渲染器运送了好几年我不知道的东西。
  • 他们加强了一些COM互操作性内容。我们遇到了一些问题,因为.pinvoke签名上的调用约定错误,.NET引发了错误-3.5会为您静默解决此问题。这些很容易解决

  • 如果您还有其他问题,请随时提问:-)

    关于.net - 改用VS10有什么经验?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3180073/

    有关.net - 改用VS10有什么经验?的更多相关文章

    1. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

      类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

    2. ruby-on-rails - Ruby net/ldap 模块中的内存泄漏 - 2

      作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代

    3. ruby-on-rails - Rails - 子类化模型的设计模式是什么? - 2

      我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co

    4. ruby-on-rails - Railstutorial : db:populate vs. 工厂女孩 - 2

      在railstutorial中,作者为什么选择使用这个(代码list10.25):http://ruby.railstutorial.org/chapters/updating-showing-and-deleting-usersnamespace:dbdodesc"Filldatabasewithsampledata"task:populate=>:environmentdoRake::Task['db:reset'].invokeUser.create!(:name=>"ExampleUser",:email=>"example@railstutorial.org",:passwo

    5. ruby - 什么是填充的 Base64 编码字符串以及如何在 ruby​​ 中生成它们? - 2

      我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%

    6. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

      我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

    7. ruby - 为什么 4.1%2 使用 Ruby 返回 0.0999999999999996?但是 4.2%2==0.2 - 2

      为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返

    8. ruby - 如何模拟 Net::HTTP::Post? - 2

      是的,我知道最好使用webmock,但我想知道如何在RSpec中模拟此方法:defmethod_to_testurl=URI.parseurireq=Net::HTTP::Post.newurl.pathres=Net::HTTP.start(url.host,url.port)do|http|http.requestreq,foo:1endresend这是RSpec:let(:uri){'http://example.com'}specify'HTTPcall'dohttp=mock:httpNet::HTTP.stub!(:start).and_yieldhttphttp.shou

    9. ruby - ruby 中的 TOPLEVEL_BINDING 是什么? - 2

      它不等于主线程的binding,这个toplevel作用域是什么?此作用域与主线程中的binding有何不同?>ruby-e'putsTOPLEVEL_BINDING===binding'false 最佳答案 事实是,TOPLEVEL_BINDING始终引用Binding的预定义全局实例,而Kernel#binding创建的新实例>Binding每次封装当前执行上下文。在顶层,它们都包含相同的绑定(bind),但它们不是同一个对象,您无法使用==或===测试它们的绑定(bind)相等性。putsTOPLEVEL_BINDINGput

    10. ruby - Infinity 和 NaN 的类型是什么? - 2

      我可以得到Infinity和NaNn=9.0/0#=>Infinityn.class#=>Floatm=0/0.0#=>NaNm.class#=>Float但是当我想直接访问Infinity或NaN时:Infinity#=>uninitializedconstantInfinity(NameError)NaN#=>uninitializedconstantNaN(NameError)什么是Infinity和NaN?它们是对象、关键字还是其他东西? 最佳答案 您看到打印为Infinity和NaN的只是Float类的两个特殊实例的字符串

    随机推荐