闭包与临时变量

import std.range;
import std.stdio;

alias NumberPrinter = void delegate();

NumberPrinter[int] printers;

void main()
{
    foreach (i; iota(5))
    {
        printers[i] = () { write(i); };
    }

    foreach (i; iota(5))
    {
        printers[i]();//输出44444
       
    }
}

可以这样

    foreach (i; iota(5))
    {
        printers[i] = (int i){
            return () { write(i); }; 
        }(i);//在外面加了一层,当前执行.
    }//写一个按值传递参数,并返回你想要的入的小函数,并立即调用,额外层让编译器及时生成一个捕获值的副本

这样

    NumberPrinter[] printers;//数组了
    static foreach (i; 0..5)
        printers ~= (){ write(i); };
    //静态

这样是不行的:

    foreach (i; iota(5))
    {
	    auto _i = i;
        printers[i] = () { write(_i); };//只是加了一个标记.
    }

也可以这样:

    foreach (i; iota(5))
    {
        printers[i] = ((i)=>{write(i);})(i);
        //上下行都可以
        printers[i] = ((i) => () => write(i))(i);
    }

这是栈桢:

   static struct __mainStackFrame
   {
       int i;
       int _i;
   }

   __mainStackFrame *frame = new __mainStackFrame; // 发生捕捉的地方
   with(*frame)
   {
      // 主函数体,都声明了
   }
   //====
       foreach (i; iota(5))
    {
	    auto _i = i;//重用_i作为闭包迭代了.
        printers[i] = () { write(_i); };
    }
    //你可能认为在生成闭包时捕捉,实际上他只是给编译器设置了个必须把外围函数放置在堆上的标记.
    //而管用的方法是因为当你返回闭包时,捕捉了嵌套调用的栈桢
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值