数组切片与字符串操作全解析
1. 数组切片的容量特性
当存在多个指向所有元素的切片时,会出现一些有趣的情况。以下代码展示了多个切片指向同一数组元素时的容量情况:
import std.stdio;
void main() {
// 三个指向所有元素的切片
int[] s0 = [ 1, 2, 3, 4 ];
int[] s1 = s0;
int[] s2 = s0;
writeln(s0.capacity);
writeln(s1.capacity);
writeln(s2.capacity);
}
输出结果显示,三个切片的容量均为 7。然而,一旦向其中一个切片添加元素,其他切片的容量将降为 0:
s1 ~= 42;
// ← s1 变为最长的切片
writeln(s0.capacity);
writeln(s1.capacity);
writeln(s2.capacity);
此时输出为:
0
7
0
这表明,添加元素的切片成为最长的切片后,只有它拥有容量。
为了避免频繁的元素复制和内存分配带来的成本,可以在已知要追加元素的数量时,预先为元素预留容量:
import std.stdio;
void main() {
int[] slice;
slice.reserve(
超级会员免费看
订阅专栏 解锁全文

349

被折叠的 条评论
为什么被折叠?



