我已经对先前编写的一些matlab代码进行了矢量化,并且在此过程中,matlab由于分段错误而开始崩溃。我将问题缩小为单一类型的计算:分配给多个结构属性。
例如,即使这种形式的自我分配最终会在执行数千次时导致seg错误:
[my_class_instance.my_struct_vector.my_property] = my_class_instance.my_struct_vector.my_property;
我最初认为这必须是某种类型的内存泄漏,因此尝试在每次迭代后打印出java的可用内存,但这仍然相当稳定。
所以是的,现在完全不知道为什么会破坏: - /
更新:以下更改修复了seg faulting:
temp = [my_class_instance.my_struct_vector];
[temp.my_property] = temp.my_property;
[my_class_instance.my_struct_vector] = temp;
现在的问题是为什么这会解决任何问题。关于重复访问句柄类而不是结构列表的事情呢?
更新2:版画更厚
我终于复制了问题和使用虚拟程序的工作,这个程序很简单,可以在这里发布:
一个简单的课程:
classdef test_class
properties
test_prop
end
end
一个程序,它会对类进行一系列向量分配,并且总会崩溃。
test_instance = test_class();
test_instance.test_prop = struct('test_field',{1 1});
for i=1:10000
[test_instance.test_prop.test_field] = test_instance.test_prop.test_field;
end
更新3:情节不佳
原来我发现了一个错误。根据Matlab技术支持,类属性的重复向量分配在R2011a(并且可能在早期版本中)中起作用。他告诉我它在R2012a中工作正常,然后提到我发现的相同解决方法:使用临时变量。
所以是啊......
非常确定这个问题以该支持票结束,但如果任何大胆的人想要了解为什么这个错误存在,我仍然对这样的答案感兴趣。 (学习很有趣!)
答案 0 :(得分:3)
到目前为止,最可能的原因是该操作在内部使用自修改代码。这个问题是现代处理器有CPU缓存,所以如果你在内存中更改代码,但代码已经提交到缓存,它将产生一个seg错误。
它是随机的原因是因为它取决于修改时修改后的代码是否在缓存中以及其他因素。
为了避免这种情况,程序员必须确保在进行自我修改之前让代码刷新缓存。