d如何推导闭包.
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 r
和ElementType!R
时,糟糕
的实现无法推导ElementType!R
并退出.
因此,必须实例化
时告诉类型
.
i.construct!(int[])((ulong i) {return cast(int)(i+i);}).print;
//要求手动加上
我懂了.问题是属性
不匹配.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现