d高阶函数与普通函数差别

原文

import std.stdio;

// 最先,需要函数指针.
T[] map_vals(T,S)(scope T function(S) f, S[] a){
    auto b = new T[a.length];
    foreach(i,x;a) b[i] = f(x);
    return b;
}

// 按编译时参数,取可调用
auto map_vals(alias f,S)(S[] a)
if (is(typeof(f(a[0]))))
{
    alias T = typeof(f(a[0]));
    auto b = new T[a.length];
    foreach (i, ref x; a) b[i] = f(x);
    return b;
}

auto timestwo(float x) {
    return 2*x;
}

void main(){
    float[] my_array = [1., 2., 3.];//浮点用法
    auto ff = (float x)=>2*x;//λ

    // 工作.
    writeln(map_vals(ff, my_array));

    // 乘2指针工作.
    writeln(map_vals(&timestwo, my_array));

    // 传递符号名,就可工作,注意UFCS语法
    my_array.map_vals!timestwo.writeln;

    // 同样
    my_array.map_vals!ff.writeln;

    // 同样
    my_array.map_vals!(x => 2*x).writeln;
}

函数参数是函数指针,ff为匿名函数指针,而乘2不是,因而这样:

writeln(map_vals(&timestwo, my_array));

λ可转换为指针.如上按编译时参数传递f(可调用).好处是可支持统调.
map标准库中,支持区间,且不分配.

posted @ 2022-02-21 19:24  zjh6  阅读(23)  评论(0)    收藏  举报  来源