1. 如果一个类的声明和实现都头文件中,并且没有相应的cpp文件,即使声明为导出类(__declspec(dllexport)),编译的动态库也不会导出此类(VS2008)。
2. 如果想要导出一种通用的算法,不依赖与数据类型,使用模板,算法的声明和实现必须都声明在头文件中,这种情况下,声明模板的动态库并不生成和导出任何函数,模板的实例是在调用模板函数的位置。还有一种情况是在声明模板的动态库中显式实例化模板函数,这种情况可以导出多种类型的函数示例,但是必须依赖这几种数据类型。
3. Qt界面布局由布局器和控件的布局方式共同控制。布局器直接控制内部控件的布局。控件设置布局方式可以像布局器一样布局内部控件或布局器。
4. 我们都知道,使用 malloc/calloc 等分配内存的函数时,一定要检查其返回值是否为“空指针”(亦即检查分配内存的操作是否成功),这是良好的编程习惯,也是编写可靠程序所必需的。但是,如果你简单地把这一招应用到 new 上,那可就不一定正确了。我经常看到类似这样的代码:
if ( p == 0 ) // 检查 p 是否空指针
return -1;
// 其它代码
其实,这里的 if ( p == 0 ) 完全是没啥意义的。C++ 里,如果 new 分配内存失败,默认是抛出异常的。所以,如果分配成功,p == 0 就绝对不会成立;而如果分配失败了,也不会执行 if ( p == 0 ),因为分配失败时,new 就会抛出异常跳过后面的代码。如果你想检查 new 是否成功,应该捕捉异常:
try {
int* p = new int[SIZE];
// 其它代码
} catch ( const bad_alloc& e ) {
return -1;
}