读你月 2015-07-24 05:19 采纳率: 0%
浏览 1513

在函数返回调用时出现缓冲区溢出问题

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;
}
程序还没写完,但是在函数返回调用时出现
图片说明
大神们,这个怎么解?
————————程序白痴

  • 写回答

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 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)