1. 函数的形参如果是多维数组,则只有第一维的大小可以被省略 void print(int [][]) ==>void print(int [][3])
2. 函数的形参如果是数组的引用,那么数组的大小要确定 void print(int (&pa)[]) ==>void print(int (&pa)[3])
数组的大小并非是函数形参的一部分,对于参数类型是数组者,如果第一维大小省略,那么唯一的操作是把数组转换成为数组指针。而对于参数类型是数组指针者,转换不会发生,所以第一维的大小也不能省略。
3. 在一组重载函数中只能有一个函数被指定为“extern "C"”! 如,extern "C" void func(int); extern "C" void func(double); extern "C"是函数类型的一部分。
4. extern 和 inline修饰词应该放在template之后,如,template <typename A, calss B> extern B funcA (A);
5. 如果模板参数有二义性,应该显示指定出模板类型,call format: funcA<double, int>(3.0); double表示input--3.0,int表示返回值类型。如果<...>中的类型可以省略,需要从右向左开始省略!
6. 布局new 操作符的两种形式:
#include<new> ---必须的
struct point;
char buffer[100];
point *pp1 = new(buffer) point; ---表示在buffer的内存地址开始处,分配一个point struct的空间,这个可以控制point对象分配的地址,在硬件设备控制中有用到。这种形式的new分配不能依靠delete操作符释放空间,buffer制定的静态的内存。
point *pp2 = new point; ---在内存中寻找合适的空间分配给point对象。可以通过delete来释放,常规new分配的空间。
7.namespace的几点注意:
例如:
namespace gaoqian
{
int a = 0;
string getValue()
{
return "namespace--gaoqian";
}
}
string getValue()
{
return "global";
}
void main()
{
using gaoqian::a;
int a = 1; //error C2374: 'gaoqian::a' : redefinition; multiple initialization,这里重复定义
using namespace gaoqian;
int a = 1; //gaoqian::a,被局部的a覆盖,编译没有错误
using gaoqian::getValue;
cout<<getValue()<<endl; //输出namespace--gaoqian,没有编译错误,全局的getValue()被覆盖
using namespace gaoqian;
cout<<getValue()<<endl; //二义性错误,不知道是调用全局的getValue(),还是gaoqian::getValue()
}
using namespace gaoqian;类似编译指令,using gaoqian::a;类似于声明指令。
可以用匿名的namespace,代替全局的static。
namespace
{
int a = 0;
}