首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

Linux c 的可变长数组

Linux c 的可变长数组

html] view plaincopy #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来分配空间,所以这种类型的数组只能够定义在栈内,不能够定义在数据段上(全局数组,静态数组)。??? 有疑问正在研究中。
返回列表