今天在在写POJ1010的时候偶然的体会到了编译器关于内存分配的一些内部机制。在程序中我用int ans[5],tmp[5];分配了两块内存
空间,编译器在分配空间的时候会是将这两块连续的分配的,相当于分配完ans立马开始tmp的分配,这个道理可能大家都知道,但
平时谁也没有在意,知道今天程序运行得到了莫名其妙的结果之后,才深刻的体会到了这点。
情况是这样的:程序在运行的过程中,即使流程不经过能改变ans中的值的语句也会导致ans中的前几个元素莫名其妙的发生值的变
化。由于程序是递归的,直接导致这个问题经过很长时间的调试才得到发现和解决。原来问题在于由于没有必要,所以在写其中某
些逻辑的时候并没有控制数组访问的界限,而正好今天的数组都分配的很精确,没有像以往那样需要10个int我就搞20个……,结果
问题就出现了,在访问并修改tmp数组中的数据的时候发生了越界,而此时并不会报越界错误,而是继续接下来访问到了ans数组中
的内容,结果就导致了ans中的数据发生了变化。