最近碰到了一个问题很棘手,C++程序在VS中编译明明什么问题都没有,但是移植到Linux下使用cmake就编译报错Segmentation fault (core dumped)。
查阅资料以后,造成Segmentation fault (core dumped)报错大多是野指针、内存越界、堆栈溢出等等,但是在VS下编译明明非常顺畅,可是问题出在哪里呢?网上搜了下在Linux下调试要使用gdb单步调试,但是今天也是刚接触Linux系统,装cmake的环境就搞了大半天,没有精力在看新的东西了……(装cmake大费周章是因为我是嫌弃命令行里连接cmake官网下载太慢了,所以投机取巧的去浏览器下载了cmake包,但是这样下载的包里缺少bootstrap,所以按照教程就进行不下去了,参考了一些资料才知道这是普遍问题,老老实实命令行里面下载就好了……)。在一系列瞎β操作,人工cout输出调试后,终于发现程序卡在了一个函数返回值是数组首地址的地方。果然是内存越界么……
进入正题
这个问题在我这里的出现原因是,在某个类的函数中,对private多个变量进行读取,然后用数组输出,原本的程序就直接定义了一个局部数组,并将其返回。
int* Cross::GetCrossInfo()
{
int crossarry[5];
crossarry[0] = m_iCrossId;
crossarry[1] = m_iRoadId1;
crossarry[2] = m_iRoadId2;
crossarry[3] = m_iRoadId3;
crossarry[4] = m_iRoadId4;
return crossarry;
}
//此时在Linux下会报错
a = b.GetCrossInfo()[1]
但是c++本身并不支持类内函数以局部变量作为返回值,因为在类外函数中,是可以通过在调用函数前创建指针int * a解决