bool intersp3(GMO &gmo,SP3 (&sp3)[3],INSP3 &insp3)
{
int gpsnum,sp3num;
sininter sdata;
gpsnum=gmo.gpsdata.size();
sp3num=sp3[1].data.size();
for(int i=0;i<gpsnum;i++)
{
for(int k=0;k<sp3num-1;k++)
{
if(gmo.gpsdata[i].hdr.epoch.isequal(sp3[1].data[k].epoch))
{
sdata.epoch=gmo.gpsdata[i].hdr.epoch;
for(int j=1;j<33;j++)
{
sdata.inter[j][0]=sp3[1].data[k].rec[j].x;
sdata.inter[j][1]=sp3[1].data[k].rec[j].y;
sdata.inter[j][2]=sp3[1].data[k].rec[j].z;
}
break;
}
else if(gmo.gpsdata[i].hdr.epoch.dayu(sp3[1].data[k].epoch)&&
gmo.gpsdata[i].hdr.epoch.xiaoyu(sp3[1].data[k+1].epoch))
{
//TODO Sliding Lagrange interpolation;
break;
}
else
continue;
}
insp3.sp3data.push_back(sdata);
}
cout<<"finished interpolation sp3 file"<<endl;
return 1;
}
程序还没写完,但是在函数返回调用时出现
大神们,这个怎么解?
————————程序白痴
在函数返回调用时出现缓冲区溢出问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答
- oyljerry 2015-07-24 05:24关注
for(int i=0;i<gpsnum;i++)
{
for(int k=0;k<sp3num-1;k++)
{
if(gmo.gpsdata[i].hdr.epoch.isequal(sp3[1].data[k].epoch))
{
sdata.epoch=gmo.gpsdata[i].hdr.epoch;
for(int j=1;j<33;j++)
{
sdata.inter[j][0]=sp3[1].data[k].rec[j].x;
sdata.inter[j][1]=sp3[1].data[k].rec[j].y;
sdata.inter[j][2]=sp3[1].data[k].rec[j].z;
}你这些数组操作可能超过了传进来的参数数组的有效范围。
解决 无用评论 打赏 举报
悬赏问题
- ¥15 Arduino红外遥控代码有问题
- ¥15 数值计算离散正交多项式
- ¥30 数值计算均差系数编程
- ¥15 redis-full-check比较 两个集群的数据出错
- ¥15 Matlab编程问题
- ¥15 训练的多模态特征融合模型准确度很低怎么办
- ¥15 kylin启动报错log4j类冲突
- ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大
- ¥15 import arcpy出现importing _arcgisscripting 找不到相关程序
- ¥15 onvif+openssl,vs2022编译openssl64