0

我们在图像处理项目中使用 Blodshed Dev-C++。我们正在视频帧上实现连接组件标签。我们必须使用一个递归函数,它递归了很多次,以至于我们得到了一个stackoverflow。我们怎样才能拥有更大的堆栈大小?是否可以通过一些链接器参数或类似的东西来改变它?

void componentLabel(int i,int j,IplImage *img){
  //   blueFrame = img->imageData[i*3*width+j*3];
//     greenFrame = img->imageData[i*3*width+j*3+1];
//     redFrame = img->imageData[i*3*width+j*3+2];

     if(!( img->imageData[i*3*width+j*3]==0 && img->imageData[i*3*width+j*3+1]==0 && img->imageData[i*3*width+j*3+2]==0 )  ){
           //printf("iffffff aq\n");
           return;     
     }
     else{
           //printf("else aq  %d\n",sayac_label);                          
               img->imageData[i*3*width+j*3]=1;  

               new_object.pixel_count=new_object.pixel_count+1;
               new_object.total_row=new_object.total_row+i;
               new_object.total_col=new_object.total_col+j;

               if(j<width-1 ){                   
                         componentLabel(i,j+1,img);                         
               }               
               if(j>0 ){                   
                         componentLabel(i,j-1,img);                   
               }             
               if(i<height-1 ){  
                         if(i>new_object.bottom.satir){
                              new_object.bottom.satir=i;
                              new_object.bottom.sutun=j;                                               
                         }

                         componentLabel(i+1,j,img);                         
               }              
               if(i>0 ){ 
                         if(i<new_object.top.satir){
                              new_object.top.satir=i;
                              new_object.top.sutun=j;                                               
                         }                  
                         return componentLabel(i-1,j,img);               
               }      
     }
4

1 回答 1

1

只有一种方法可以保证您不会用完堆栈大小-将算法重新定义为尾递归(并确保您的编译器正在优化尾调用-通常是-O3(或-O2?)优化标志)。

除此之外,您是否增加了 shell 将授予您的任务的最大堆栈大小?

  ulimit -s <maximum stack size>
于 2012-04-15T04:29:54.440 回答