首页 > 代码库 > 内存分配与Segmentation fault
内存分配与Segmentation fault
为了方便使用,我做了如下结构体的嵌套使用:
struct operation{
int num;
char name[100];
char owner[100];
char msg[100];
};
struct collect{
int num;
char name[100];
char owner[100];
char msg[100];
struct operation operations[100];
};
struct list{
int num;
char name[100];
char owner[100];
char msg[100];
struct collect collects[100];
};
而后在main中做如下的使用:
struct list lists[100];
编译没有任何问题,在执行时报错:Segmentation fault 即段错误,一般是对内存的非法使用导致的
我将所有代码注释掉,只剩下这一个申明,结果依然报错
于是怀疑是申请的内存过大,超出了限制
后查到:局部变量是放在栈的,而linux对栈的使用有限制,可通过ulimit -s查看和更改
后做实验:调整局部变量的大小和栈使用限制,发现确实如此
结论:对于大数据,不能使用栈分配,可以考虑静态区和堆区,例如:1)定义为全局变量、2)定义为static变量、3)使用malloc动态分配
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。