首先用typedef定义两个float[]数组类型
typedef float Math3DVector2f[2];
typedef float Math3DVector3f[3];
再分别用上面两个类型变量重载一个函数NormalizeVectorf
void NormalizeVectorf( Math3DVector2f vectorf )
{
//----
}
void NormalizeVectorf(Math3DVector3f vectorf )
{
//----
}
对比上面两个函数,看起来因为参数不同而实现了重载。但是本质上他们是重复定义,并不是重载,会导致编译错误。原因是,两个参数都是同类型的参数,不管是第一个函数参数float[2],还是第二个函数参数float[3],编译器在编译的时候一律当做float[]。由此这两个函数在编译阶段被认为是一个函数的重复定义.