d如何推导闭包.

1002 篇文章 1 订阅
import std.stdio;
import std.algorithm;
import std.traits;
import std.range;

void print(R)(R r) {
  static assert(isIterable!R);
  r.each!writeln;
}

auto construct(R)(R r, ElementType!R delegate(ulong i) fn) {
  static assert(isIterable!R && hasAssignableElements!R);
  ulong i = 1;
  r.each!((ref e) => e = fn(i));
  return r;
}

unittest {
  int[] i; i.length = 4;
  i.construct((ulong i) {return cast(int)(i+i);}).print;//不能重载.
}//错误消息中的`pure nothrow @nogc @safe`从哪来?

为何(ulong i) {return cast(int)(i+i);},按函数传递?闭包函数错误消息相同

可用construct!(int[])而不是普通的construct来完成工作.这是dmd实现中(非常烦人的)缺陷.sdc可搞定.
因为它是闭包字面,所以会自动找出最紧密属性.因而是函数(未用环境变量),
但所有这些都隐式转换了,所以并不重要.类型系统允许这样,只是当提及R rElementType!R时,糟糕的实现无法推导ElementType!R并退出.
因此,必须实例化时告诉类型.

i.construct!(int[])((ulong i) {return cast(int)(i+i);}).print;
//要求手动加上

我懂了.问题是属性不匹配.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值