- #include <stdio.h>
- #include <stdlib.h>
- #include <string.h>
-
- static char arry_b[0];
-
- void lengthen_arry(int n)
- {
- const char *head = "headstr-";
- const char *tail = "tailstr";
-
- char arr[n+1];
- char vla[strlen(head) + strlen(tail) + 1];
-
- int i;
-
- strcpy(vla, head);
- strcat(vla, tail);
-
- printf("%s\n", vla);
-
- for(i = 0; i < 5; ++i)
- {
- char foo[i + 2];
- strncpy(foo, "xxxxxxxxxxx", i + 1);
- foo[i + 1] = '\0';
- printf("%s\n", foo);
- }
-
- bzero(arr, (n+1) * sizeof(char));
-
- for (i = 0; i < n; i++) {
-
- arr[i] = (char)('A' + i);
- arry_b[i] = (char)('A' + i);
-
- }
-
- arr[n] = '\0';
- arry_b[n] = '\0';
- printf("length_arry:%s:%s\n", arr, arry_b);
- }
-
- typedef struct _t {
- size_t size;
- char *s;
- }s_t;
-
- void lengthen_arry_2(char *str)
- {
- s_t *t;
- t = (s_t *)malloc(sizeof (s_t) + strlen(str));
-
- t->size = strlen(str);
-
- t->s = (char *)t + sizeof(s_t);
-
- strncpy(t->s, str, t->size);
-
- printf("s_t:%s\n", t->s);
- free(t); //只要一次釋放就可以
- }
-
- int main(int argc, char *argv[])
- {
- lengthen_arry(6);
- lengthen_arry_2("lengthen_arry");
- return 0;
- }
大家看看上面代碼的優缺點!
/*=============*/
在C99中新加入了對變長數組的支持,即數組的長度可以由某個非const變量來定義。
可變數組的空間大小直到程序運行時才能確定,因此只有程序在運行時才能為程序分配空間。
在gcc編譯器程序會在運行時根據實際指定的大小(變量當前的值)調節esp的值,為數組在棧上分配適當大小的空間。
由於要在運行時才能為數組分配空間,在開始分配空間之前空間的大小是不確定的,因此分配空間的起始地址也是不確定的(例如要在棧上分配兩個可變長數組的情況下)。
為了在以後的代碼中對可變長數組的內容進行引用操作,程序必須通過某種方式獲取可變長數組的地址。
在gcc編譯器中會在相對於ebp固定的偏移量的棧上分配的一個固定大小的區域(稱為內情向量)來記錄可變長數組的信息,如數組的開始地址等。
後繼代碼通過內情向量中的起始地址訪問可變長數組。
因為數組依靠在程序運行時動態的調整esp來分配空間,所以這種類型的數組只能夠定義在棧內,不能夠定義在數據段上(全局數組,靜態數組)。??? 有疑問正在研究中。