d的数组打败了C++的点点点

原文,你看:

void test()
{
    auto a = [1, 2, 3];
    int[3] b = a[]*a[]; // b[0] = a[0]*a[0]; b[1] = a[1]*a[1]; b[2] = a[2]*a[2];
    int[3] c = a[]*2; // c[0] = a[0]*2; c[1] = a[1]*2; c[2] = a[2]*2;
}

D元组已经有了数组语法了,可索引,可切片.不用...,我们有数组语法.

(Tup*10)...  -->  ( Tup[0]*10, Tup[1]*10, ... , Tup[$-1]*10 )
//对比
Tup*10
//--------
alias Tup = AliasSeq!(1, 2, 3);
int[] myArr;
assert([ myArr[Tup + 1]... ] == [ myArr[Tup[0] + 1], myArr[Tup[1] + 1], myArr[Tup[2] + 1] ]);

//---对比数组
alias Tup = AliasSeq!(1, 2, 3);
int[] myArr;
assert([myArr[Tup+1]]==[myArr[Tup[0]+1],myArr[Tup[1]+1],myArr[Tup[2]+1]]);
//--------
alias Values = AliasSeq!(1, 2, 3);
alias Types = AliasSeq!(int, short, float);
pragma(msg, cast(Types)Values...);

//---对比
alias Values = AliasSeq!(1, 2, 3);
alias Types = AliasSeq!(int, short, float);
pragma(msg, cast(Types)Values);
//--------
alias OnlyTwo = AliasSeq!(10, 20);
pragma(msg, (Values + OnlyTwo)...);
//---对比Array
alias OnlyTwo = AliasSeq!(10, 20);
pragma(msg, Values + OnlyTwo);

理念就是,如果我们有t op c,t为元组,c不是元组.则结果是:

tuple(t[0] op c, t[1] op c, ..., t[length - 1] op c)

t1 op t2,两个都是元组,则结果是:

tuple(t1[0] op t2[0], t1[1] op t2[1], ..., t1[length - 1] op t2[length - 1])

不需要遍历AST,只需按通常自下而上语义处理,即可.优点是:

序号优点
1无新语法
2无新运算符优先规则
3转换当前为错误的式为显而易见的事情

为什么C++使用...而不是数组语法?因为C++没有数组!

posted @   zjh6  阅读(13)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示