d代码为啥错
import std.stdio;
import std.string;
import std.algorithm : until;
void main() {
ubyte[8] b = [0x68, 0x65, 0x6C, 0x6C, 0x6F, 0x0A, 0x00, 0x00];
/* "hello\n\0\0" */
writefln("'%s, world'", cast(char[])b[].until('\n'));
}
p1.d(9): Error: cannot cast expression `until(b[], '\x0a', Flag.yes)` of type `Until!("a == b", ubyte[], char)` to `char[]`
SS
:你缺少()
,cast
优先级很低,这里情况是这样的:
先求值b[].until('\n')
,先返回Until!...
构,而它无法转为char[]
.而我会
(cast(char[])b[]).until('\n')
这样转换,先转换ubyte
数组为符数组
,再跑until
.
原文
下面是工作版本:
import std.stdio;
import std.string;
import std.algorithm : until, map;
import std.conv : to;
void main() {
ubyte[8] b = [0x68, 0x65, 0x6C, 0x6C, 0x6F, 0x0A, 0x00, 0x00];
/* "hello\n\0\0" */
writefln("'%-(%s%), world'", b[].until('\n').map!(to!char));
}
用map!(to!char)
来转换ubyte
区间元素至char
,然后用%-(...%)
格式化器来打印出来.
原文
问题:
.until()
会复制原串吗?GC
再利用它?
不,until
迭代至该符,并排除它,其不会复制数据
.它实际上是一步完成修剪
与迭代打印
,你早期例子用了3步,找尾符
,去新行,再打印出来.
许多方法,printf("%s", (char*)buf)
?
有很多方法实现,我是这样的:
序号 | 步骤 |
---|---|
1 | 尽量不分配.无论垃集 与否,我讨厌仅为了打印串 而分配串,然后再丢弃它. |
2 | 简洁并仔细读 |
3 | 尽量有效. |
注意cast
,不过,这是当你分配
时才无法避免.2/3
有时冲突,但为了性能,1
是重要的.
C
只能printf
.
还可试试:
auto s = fromStringz(cast(char*)ioCtx.buf.ptr)
都可用区间
和算法
搞定,如果你不适应,可写个包装器
,不难.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现