D 中缓存友好的多维数组迭代

min*_*xew 3 caching d multidimensional-array

我在 D 中有一个静态3 维数组,一般来说

Struct[WIDTH][HEIGHT][DEPTH] values;
Run Code Online (Sandbox Code Playgroud)

这些维度中的两个变成了数千。如果我想线性地遍历这个访问内存位置的数组,应该在外循环中遍历哪个维度?WIDTH或者DEPTH

yaz*_*yaz 5

外循环应该DEPTH由以下程序证明:

import std.stdio;

void main() {
  enum X = 6, Y = 4, Z = 2;
  ubyte[X][Y][Z] root;

  foreach (i, ref level3; root) {
    foreach (j, ref level2; level3) {
      foreach (k, ref level1; level2) {
        writefln("%s %s %s: 0x%x", i, j, k, &level1);
      }
    }
  }   
}
Run Code Online (Sandbox Code Playgroud)

这打印:

0 0 0: 0x7fbfc8b9f0
0 0 1: 0x7fbfc8b9f1
0 0 2: 0x7fbfc8b9f2
0 0 3: 0x7fbfc8b9f3
0 0 4: 0x7fbfc8b9f4
0 0 5: 0x7fbfc8b9f5
0 1 0: 0x7fbfc8b9f6
0 1 1: 0x7fbfc8b9f7
0 1 2: 0x7fbfc8b9f8
0 1 3: 0x7fbfc8b9f9
0 1 4: 0x7fbfc8b9fa
0 1 5: 0x7fbfc8b9fb
0 2 0: 0x7fbfc8b9fc
0 2 1: 0x7fbfc8b9fd
0 2 2: 0x7fbfc8b9fe
0 2 3: 0x7fbfc8b9ff
0 2 4: 0x7fbfc8ba00
0 2 5: 0x7fbfc8ba01
0 3 0: 0x7fbfc8ba02
0 3 1: 0x7fbfc8ba03
0 3 2: 0x7fbfc8ba04
0 3 3: 0x7fbfc8ba05
0 3 4: 0x7fbfc8ba06
0 3 5: 0x7fbfc8ba07
1 0 0: 0x7fbfc8ba08
1 0 1: 0x7fbfc8ba09
1 0 2: 0x7fbfc8ba0a
1 0 3: 0x7fbfc8ba0b
1 0 4: 0x7fbfc8ba0c
1 0 5: 0x7fbfc8ba0d
1 1 0: 0x7fbfc8ba0e
1 1 1: 0x7fbfc8ba0f
1 1 2: 0x7fbfc8ba10
1 1 3: 0x7fbfc8ba11
1 1 4: 0x7fbfc8ba12
1 1 5: 0x7fbfc8ba13
1 2 0: 0x7fbfc8ba14
1 2 1: 0x7fbfc8ba15
1 2 2: 0x7fbfc8ba16
1 2 3: 0x7fbfc8ba17
1 2 4: 0x7fbfc8ba18
1 2 5: 0x7fbfc8ba19
1 3 0: 0x7fbfc8ba1a
1 3 1: 0x7fbfc8ba1b
1 3 2: 0x7fbfc8ba1c
1 3 3: 0x7fbfc8ba1d
1 3 4: 0x7fbfc8ba1e
1 3 5: 0x7fbfc8ba1f
Run Code Online (Sandbox Code Playgroud)

请注意,地址以线性方式增加,并且变化最快的索引是X。所以内循环代表X,外循环代表Z