extern 数组

最近比较关注C++对象的Linkage类型,然后今天突然想起extern数组这个奇葩的东西,稍微折腾了一下,顺手写个随笔。

首先在cpp中定义几个数组:

 int extern_array[] = {,,,,};
int extern_array_normal[] = {,,,,};
extern const int extern_array_normal_const[] = {,,,,};

然后再另一个cpp中使用:

extern int* extern_array;
extern int extern_array_normal[];
extern int const extern_array_normal_const[]; int _tmain(int argc, _TCHAR* argv[])
{
int address = reinterpret_cast<int>(&extern_array);
int first = *reinterpret_cast<int*>(address);
int second = *reinterpret_cast<int*>(address + * sizeof(int));
int third = *reinterpret_cast<int*>(address + * sizeof(int)); int* address_ptr = reinterpret_cast<int*>(&extern_array);
first = address_ptr[];
second = address_ptr[];
third = address_ptr[]; int normal_first = extern_array_normal[];
int normal_second = extern_array_normal[];
int normal_third = extern_array_normal[]; int normal_first_const = extern_array_normal_const[];
int normal_second_const = extern_array_normal_const[];
int normal_third_const = extern_array_normal_const[]; size_t size_of_array = sizeof(extern_array_normal);
//size_t size_of_array_const = sizeof(extern_array_normal_const); //error C2070: 'const int []': illegal sizeof operand return ;
}

上面的Demo简单演示了extern数组各种使用的方法。

但是有种奇葩的情况是:

 extern int* extern_array;

extern_array的内容实际上在Link处理完之后,竟然变成了extern_array[]首地址。也就是说在另一个文件中通过extern_array[index](也就是*(extern_array + 1)),

相当于    “extern_array的值 + index * sizeof(int)" 得到的value值,然后再解引用*value。假设index = 0,那么value的值为0x0000000A, 解引用。。。然后发生神马事情,不用说都知道,那么低的地址(空指针赋值地址分区)。。。。。。。

那extern int extern_array*岂不是不可以用了,虽然以下做法并不推荐,但是如果你真想用这个方法的话,可以先取extern_array得地址,然后保存到一个指向int的指针当中,这样就可以还原数组(或者指针)寻址的操作。

2014年3月28日补充:

extern int extern_array* 只是反面教材,一般不会那么搞。上面提供的方法,仅供观赏,实际生产当中,谁那么写,必然被批。

上一篇:Jsp页显示时间标签JSTL标签 实例大全


下一篇:Vue框架创建项目常遇到问题