本文是对http://www.davidlenihan.com/2008/01/choosing_the_correct_cc_runtim.html的翻译,如有错误,还请指正
c/c++运行库(runtime library)包括许多基本的功能,像内存分配、输出和字符串操作(复制、计算长度)等等
当建立了一个c/c++的应用程序或库时,你必须选中c/c++运行库,在vs2005中,你可以这样选中这种按钮:Project->Properties...->Configuration Properties->C/C++->Code Generation->Runtime Library:
这里有4种选择:
1 多线程(/MT)
2 多线程调试(/MTD)
3 多线程动态链接库dll(/MD)
4 多线程动态链接库调试(/MDD)
c++的运行库依赖于c的运行库。c的运行库版本必须和c++的运行库版本匹配。因此,这些选项应用于c和c++的运行库中。
在之前vs的版本中,这些都是单线程的。那些版本会比多线程的执行的速度更快。但是,在多线程的应用程序中,用他们并不安全。我想,单线程库在减少是因为多核现在已经成为普遍的存在。而且多线程应用程序需要利用多核。
(In previous versions of Visual Studio, you had additional options that were single-threaded. These versions would execute faster on a single core than the multi-threaded versions. However, they were not safe to use in a multi-threaded application. I'm guessing these libraries were dropped since multiple cores are quickly becoming ubiquitous and multi-threaded applications are needed to take advantage of these extra cores.)
这两种变量会有四种选择
- 调试版本(debug) vs 发布版本(release)
- 动态链接库(dll)vs 静态库
第一种变量很简单,在不交给顾客的内部软件中应用调试版。调试的运行库不能合法的包含你的应用程序。这么说吧,你不能将软件的debug版本交给顾客。它应该是运行库的release版本
debug运行库让你会的一些有用的调试帮助,比如错误报告和跟踪内存泄露,想了解更多的debug功能,请看http://msdn.microsoft.com/en-us/library/zh712wwf%28VS.80%29.aspx
下一个变量就是动态链接库(dll)或静态库了。通常来说,我们应当使用dll,当出现下面请看时,你可以考虑静态库版本:
- 你有一个小的应用程序,你不想浪费内存让运行库调用一些你不想要的东西上面
- 你想要一个简单的应用程序不依赖于额外运行库的dll
当你的应用程序不需要其他库时这些指令运行的非常好。但这很少发生。在应用程序中使用多余一个运行库版本Microsoft列出了几点模糊的警告在他们的文档里。
目的就是在你的整个应用程序里只使用一种运行库。
但这几乎不可能因为因为你对别的类库用了什么库时没有权限的。比如说,openGL(open graphic library)需要使用类库。如果你的应用程序或是使用的其他类库没有和openGL使用同样的类库,那么你就在同时用着几个类库。
我们怎么知道某个exe,dll,lib,obj使用了哪个类库呢,使用下面这条命令:、
dumpbin /all XXXX | find /i "msvcr"
XXX表示你想知道的exe/dll/lib/obj
想知道运行的结果代表什么,可参照:http://msdn.microsoft.com/en-us/library/abx4dbyh.aspx
如果你什么也没得到,很可能你现在用的是一个静态库。
甚至在你知道用的是哪个运行库,你会发现要使得应用程序只用一个运行库也是不可能的。如果如果你匹配运行库,会发现,有可能一个类库用的是vs7.0的版本(msvct.dll)但是你只能访问vs8.0的类库。
所以,除了某些特定情况,类库混在一起用关系不大。一个好的类库应该避开这些情况,然后类库匹配的时候就没多大关系了。