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)

都可用区间算法搞定,如果你不适应,可写个包装器,不难.

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