d中的列表
原文
只需使用类似C++
向量的T[]
,
每个集合
都有自己特殊接口
.面向对象
不适合集合
.如,你不希望索引
链表.
在Java
中有数组列表
,在C++
中有std::vector'
等等.它们幕后都是动态数组
.
数组
比链表
好得多,链表用途不大.
0,数组
使用的内存
更少
1,提供常数
时间访问
元素
2,常数
时间加元素
3,有时,常数
时间删元素(删最后元素)
4,排序后,可在logN
时间内查找
元素
5,数组从CPU
获得特殊帮助(如预取
缓存)
D
用区间示例列表
:
struct List(A) {
A[] *arr;
auto put(R)(R value) { (*arr) ~= value; }
auto length() { return (*arr).length; }
auto empty() {
import std.range : empty;
return (*arr).empty;
}
auto front() {
import std.range : item = front;//back;
return (*arr).item;
}
void popFront() {
import std.range : next = popFront;//popBack
(*arr).next;
}
}
auto listHelper(A)(return ref A[] arr) {
return List!A(&arr);
}
alias immutable(char[]) [] strings;
void main() {
strings myNames = ["El-Mevla", "Hodja", "Nasreddin", "Sivrihisar", "Shemseddin", "Nasruddin", "Nusrat"];
strings list;
auto myList1 = listHelper(list);
import std.range;
auto myList2 = appender!strings;
import std.container.array;
auto myList3 = Array!string();
foreach(name; myNames)
{
myList1.put(name);
myList2.put(name);
myList3.insert(name);
}
void rangePrint(R)(R range)
{
import std.stdio;
size_t i = 1;
foreach(item; range)
{
writeln(i++, ": ", item);
}
writeln;
}
rangePrint(myList1);
rangePrint(myList2);
rangePrint(myList3);
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现