有两个type类型的数组A和B,大小均为N,N可能几十万大小。
当使用如下赋值方法时,提示stack overflow
A=B
当该成DO循环赋值时,就正常通过
do i=1,N
A(i)=B(i)
end do
网上找不到具体的原因,相关的问题整理如下:
http://emuch.net/html/201001/1800067.html
http://tieba.baidu.com/p/691353242
http://tieba.baidu.com/p/691353242
(1)整体赋值时都要放到stack里面,当循环赋值时则一个一个进入stack,不会出现溢出。
(2)貌似楼主有两个N X N维的数组,如果这个是放在stack里的话,那就是非常大的了。
我不清楚FORTRAN的语法,不知道楼主声明数组的方式是不是会把数组放在stack里。
如果是放在stack里的话,建议搂住把数组放到Heap里。
ps:stack就是堆栈,Heap就是堆。每个线程都有自己的stack用来保存局部变量和函数调用信息,根据编译器不同,通常大小1~4MB
之间,如果用完了就会出现stack overflow exception。
如果楼主不清楚的话,建议看一下Fortran语法关于内存管理的部分,非常大的数组应该是动态管理的,放在heap里。
(3)我同事原来也遇到过类似的问题,后来把project设置里的堆栈加大就可以了,默认是1M,你可以加大到10M试试.
project-> setting-> link:
在category里选择output,在stack的Reserve里输入0x10000000试试
(4)二楼没说原因。一般来说,全局变量和静态变量在数据段,大小几乎没有限制,也就是跟系统能访问的内存大小相符。局部变
量在栈区,但是大小有限制,跟编译器设置有关。动态分配内存在堆区,大小跟全局变量的一样。
所以楼主的程序局部变量使用过多,导致栈溢出。这么大肯定溢出,这个变量在主程序和子程序中都是局部变量,只有放在程序之外
声明才是全局变量,或者用动态分配。
(5)Fortran程序中报错stack overflow:
一般Fortran编译器默认情况是allocatable array放在堆里, Automatic Array放在栈里. 栈的缺省设置一般为1048576 Byte = 1MB.
数组越界, 在Visual Fortran里提示stack overflow. 在Fortran77这样的UNIX平台下的编译器里通常是core dump. 这时把栈的缺省
设置改大即可.
办法:(VISUAL FORTRAN里建立的该程序的WORKSPACE窗口内)
MAIN MENU: Project ===> Setting ===> Link ===> Category : Output ===> Stack Allocations ===> Reserve : (栈大小)
1MB: 1048576 Byte
10MB: 10485760 Byte
64MB: 67108864 Byte
100MB: 104857600 Byte
128MB: 134217728 Byte
256MB: 268435456 Byte (MAX)