d无间接隐式转为可变
原文
无间接
的不变
表达式不转换为可变
.
void main() {
const i = 42; // 常,所以T应为常.
foo(i);
}
void foo(T)(T value) {
T result;
++result; // 编译错误,但是否应工作?
}
我觉得它应可工作,因为"结果
"是局部
整数.
但不能推导它为"int"
,否则会丢失
限定符,并且在进一步
模板推导
会出错.我认为是缺少Unqual
.
这样:
void main() {
auto foo = const Foo("whatever");
bar(foo);
}
struct Foo {
char[] data;
}
void bar(T)(T value) {
T thing = value;
thing.data[0] = 'a';
}
你希望由于写入只读内存
,在编译时还是运行时出错?
很公平,但该类型
具有间接性
.我"感觉
"对无间接
的基本类型等,应该可以,我知道会破坏推导模板类型
及重载函数
.
必须添加类型系统
中的异常
,才能使其仅适用于基本类型
.对切片,指针,结构和类
等其他类型,它会变得很危险
.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现