我想通过子类型多个结构间共享一个数组,我尝试了这个,发现了一些奇怪的行为.

class SharedArray(T) {
  public T[] array;
  alias array this;  // 子类型
}

alias Filenames = SharedArray!(string);

struct S {
  Filenames fns;
  void alloc() {
    fns = new Filenames();
  }
}

void main(string[] args) {
  S s0;
  s0.alloc();
  s0.fns ~= "abc";

  foreach (i; 0..3) {
    S* s1 = new S();
    *s1 = s0;   //  从s0复制到*s1
    writeln(s0.fns);
  }
}
//输出:
["abc"]
[]
[]

别名本,与类等引用类型交互奇怪的怪癖
传递区间writeln时,它用frontpopFront迭代区间来打印每个元素.这样会消耗区间.
通常,这不是问题,因为writeln按值取其参数,因此会复制传递给它的区间,并且只会消耗副本.但是,因为你用alias this来放入Filenames类输入区间,且类是引用类型,所以使用该区间的副本也会消耗原始区间.
解决方案是使用std.range中的save函数创建区间独立副本,以供writeln迭代:

import std.range;
writeln(s0.fns.save);