以下简单的代码返回,在我看来,是一个意想不到的结果:
3-element Array{Array{Float64,2},1}:
2x2 Array{Float64,2}:
1.2821 -2.10146
-1.00158 1.8163
2x2 Array{Float64,2}:
1.2821 -2.10146
-1.00158 1.8163
2x2 Array{Float64,2}:
1.2821 -2.10146
-1.00158 1.8163
当我运行上面的代码时,我的数组A读取:
for dd=1:3
A[dd] = zeros(2,2)
end
当我实际创建它们时,为什么三个2x2矩阵是相同的?
我确实理解在将数组分配给Julia中的数组时必须要小心,但不知怎的错误让我不知所措。
我发现的有趣的事情是,如果我初始化A如下:
fill!(A, zeros(2,2))
与
相反3-element Array{Array{Float64,2},1}:
2x2 Array{Float64,2}:
-0.176283 0.22073
-1.71021 -0.575144
2x2 Array{Float64,2}:
1.94395 1.09946
1.65326 -0.446783
2x2 Array{Float64,2}:
1.2821 -2.10146
-1.00158 1.8163
如上所述,然后我得到了我认为正确的结果:
InputMethodManager imm = (InputMethodManager) cntx.getSystemService(Activity.INPUT_METHOD_SERVICE);
imm.toggleSoftInput(InputMethodManager.HIDE_NOT_ALWAYS, 0);
请注意,最后一个矩阵是上面重复的矩阵。
数组初始化是错误的还是赋值? 我想这是两者的结合,取决于你是如何做到的。 提前谢谢。
答案 0 :(得分:5)
你几乎自己回答了。是的,
fill!(A, zeros(2,2))
是罪魁祸首,在命令之后,A的每个单元格包含相同的数组(连接到内存中相同的2x2点)。函数zeros
被调用一次。
在循环中填充数组的单元格
for dd=1:3
A[dd] = zeros(2,2)
end
调用函数zeros
3次,为每个单元格(位于内存中的不同位置)返回不同的零数组。