1

为什么我不能使用std.algorithm.iteration.sumwith Duration[]

我认为我可以使用与使用sum相同的方式,例如int[]

int[] ints = [40, 27, 5];
int intSum = ints.sum();
assert(intSum == 72);

但相反,我得到了一个意外的(至少对我来说是意外的)编译错误:

/usr/include/dmd/phobos/std/algorithm/iteration.d(5885): Error: struct `core.time.Duration` member this is not accessible
so_002.d(11): Error: template instance `std.algorithm.iteration.sum!(Duration[])` error instantiating

我有点理解编译错误,但我不明白为什么存在限制,因为对我来说,文档中没有任何内容可以解释这一点。

我读过了:

Duration[]符合 的约束sum

auto sum(R)(R r)
if (isInputRange!R && !isInfinite!R && is(typeof(r.front + r.front)));

还是我忽略了其他东西?

解决方法很简单 -fold改为使用。

import std.algorithm : fold, sum;
import std.datetime : Duration, minutes;

void main()
{
  Duration[] durations = [40.minutes, 27.minutes, 5.minutes];

  // Unexpected compilation error:
  // /usr/include/dmd/phobos/std/algorithm/iteration.d(5885): Error: struct `core.time.Duration` member this is not accessible
  // so_002.d(11): Error: template instance `std.algorithm.iteration.sum!(Duration[])` error instantiating

  // auto durationSum = durations.sum();

  // fold works as expected
  Duration durationSum = durations.fold!((a, b) => a + b);
  assert(durationSum == 72.minutes);
}
4

1 回答 1

2

这里的问题是sum零参数(UFCS arg 除外)试图通过调用构造函数来创建值为零的种子元素Duration(0)。虽然Duration(0)有点道理,但Duration(1)- 一分钟的价值是多少?一秒?一个永恒?因此,Duration(0)根本无法编译。之所以fold有效,是因为它总是以第一个元素为种子。缺点是当它操作的范围为空时会抛出。

现在,你可能不太在意这些,只想durations.sum()工作。不要担心——有办法的。您必须将种子值传递给sum()as durations.sum(Duration.zero)

归档为错误:https ://issues.dlang.org/show_bug.cgi?id=19525

于 2018-12-30T17:32:23.370 回答