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++
没有数组!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现