d我想要动态模板虚
template T(int i=3)
{
mixin template M(int m)
{
enum t = i;
}
}
{
mixin T!1.M!1;
pragma(msg, t); // 1
}
{
mixin T!().M!1;
pragma(msg, t); // 3
}
{
mixin T.M!1;
pragma(msg, t);//我想省略`!()`.
}
用别名
,如
alias t = T!();
目前,没好办法.
我想保留t != T
,但不能:alias T = T!()
,报已定义T
.
alias T = TImpl!();
模板与模板函数
,这里有些不一致:
import std.stdio;
void f(int i=3)()
{
writeln(i);
}
void main()
{
f!1; // 1
f!(); // 3
f; // 3
}
化简:
template T(int i = 3) {
enum value = i;
}
void main() {
pragma(msg, T!().value); //要求T!()
}
用定型模板,同样有不一致
struct S(int i = 3) {
}
void main() {
S!() s; // 要求S!()
}
应该改.
函数模板
可从函数参数
隐式实例化.而模板
不行.
要加个!()
来实例化.函数不能返回
类型别名.你做不到.只能加!()
或用不同别名
.
class Base {
virtual string serialize(this This)() {
return This.stringof; // 示例
}
}
class Derived : Base {
}
void main() {
Base b = new Derived();
assert(b.serialize() == "Derived");
}
当前,仍然是返回
基类.如果能够动态
应该是比较好的.
但,如果序化
有个虚表项
,就像不是模板
一样.每个子类自动得到自己
的实例.
虽然crtp/模板插件
可实现,但继承类都必须在子类
写它.
如果再次
为子类自动实例化
基类模板,但仍像普通虚调用
一样工作,那就太酷了.
我把typeof(this)
放入(暴露前向引用编译器漏洞闻名的)模板插件
中来实现.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现