C语言柔性数组


1、柔性数组
    C语言中结构体的最后一个元素可以是大小未知的数组
    C语言中可以由结构体产生柔性数组
 typedef struct _soft_array
  {
     int len;
     int array[];
 }SoftArray;
    可以试试,printf("%d", sizeof(SoftArray));打印出它的sizeof()大小
    结果是4,也就是说array[]这个未知长度的数组占了0字节,也就是传说中的柔性数组。
 因此 我们可以有这样的程序了
     int i = 0;
     SoftArray* sa = (SoftArray*)malloc(sizeof(SoftArray) + sizeof(int) * 10);
     sa->len = 10;
     for(i=0; ilen; i++)
     {
         sa->array[i] = i + 1;
     }
     for(i=0; ilen; i++)
     {
         printf("%d\n", sa->array[i]);   
     }
     free(sa);
这样我们为结构体指针sa分配了一块内存。但是这个时候我们再用sizeof(*sa)测试结构体的大小,发现仍然是4.可见,结构体的模已经定了。而多分配出来的内存是又变长数组使用。
    2、const  volatile
    这两个可能知道的人会经常用,用的也非常多,但是两个合在一起用呢?哈哈
    C语言中的const 不是真正意义的定义一个常量  而是定义了一个只读变量也就是说const int i = 0;中i的本质还是变量,只是声明为const就导致编译器不让这个变量出现在赋值符号左边,但i还是有自己的内存空间,有自己的值。
    volatile是告诉编译器每次程序读值的时候就到内存中去取值,而不要做优化。
    因此
    const volatile int i = 0;是合法的  const告诉编译器 这个变量i不能成为左值,并且告诉编译器当我们使用i的值时,比如 int j = i;这个时候我们要到内存中拿i的值。为什么这么说呢,因为编译器看到i是const的,就会认为i的值不会变了,而默认看到i就是0,其实因为i有自己的内存空间,所以我们可以通过硬件方式或者 直接修改它的内存的方式来改变i的值   如果不加volatile  那么很可能i在内存中的值已经变了,但是编译器还是认为i为0
发布了14 篇原创文章 · 获赞 6 · 访问量 3万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章