erlang学习:用ETS和DETS存储数据

作用

ets和dets是两个系统模块,可以用来高效存储海量的Erlang数据。

ETS和DETS执行的任务基本相同:它们提供大型的键值查询表。ETS常驻内存,DETS则常驻磁盘。ETS是相当高效的:可以用它存储海量的数据(只要有足够的内存),执行查找的时间也是恒定的(在某些情况下是对数时间)。DETS提供了几乎和ETS一样的接口,但它会把表保存在磁盘上。因为DETS使用磁盘存储,所以它远远慢于ETS,但是运行时的内存占用也会小很多。另外,ETS和DETS表可以被多个进程共享,这就让跨进程的公共数据访问变得非常高效。

ETS表广泛应用于那些必须以高效方式操作大量数据的应用程序,以及用非破坏性赋值和"纯"Erlang数据结构编程的开销过大之时。

ETS和DETS表保存的是元组。

下面是ets初步学习的代码示例

erlang 复制代码
-module(ets_test).

-export([]).

%% API
-export([start/0]).

start() ->
  lists:foreach(fun test_ets/1,
    [set, ordered_set, bag, duplicate_bag]).

test_ets(Mode) ->
  TableId = ets:new(test, [Mode]),   %%创建一个指定类型的ets表
  ets:insert(TableId, {a, 1}),
  ets:insert(TableId, {b, 2}),
  ets:insert(TableId, {a, 1}),
  ets:insert(TableId, {a, 3}),
  List = ets:tab2list(TableId),
  io:format("~-13w => ~p~n", [Mode, List]),
  ets:delete(TableId).

其中代码演示了四种模式下的ets会创建一个什么类型的表

set下为异键表,要求键是唯一的(异键)

ordered_set则是要求表的键是排好序的(有序异键)

bag则为同键表,允许多个元素拥有相同的键,但不能有相同键值对(同键)

而duplicate_bag不仅能够有相同的键,键所对应的值也能够相同(副本同键)

以下是测试代码

可以看到输出结果与预期相符,set中只有最后输入的保留下来,键相同的都被后添加的覆盖掉了。而bag中没有相同的两个{a, 1},但duplicate_bag有

相关推荐
张望远-长风万里4 分钟前
练习实践-win10自带命令工具certutil进行文件校验和生成实践
学习
敲敲了个代码9 分钟前
从零实现一个「就地编辑」组件:深入理解 OOP 封装与复用的艺术
前端·javascript·学习·面试·前端框架
YJlio9 分钟前
Autologon 学习笔记(9.16):无感登录的正确打开方式(原理、风险与替代方案)
数据库·笔记·学习
不羁的木木26 分钟前
【开源鸿蒙跨平台开发学习笔记】Day10:React Native 开发 OpenHarmony —— 渲染README文档
学习·开源·harmonyos
d111111111d29 分钟前
在stm32F103C8T6中,Thumb指令是什么?有什么作用?可以干什么?
笔记·stm32·单片机·嵌入式硬件·学习
哟哟耶耶1 小时前
knowledge-scss学习
前端·学习·scss
cjy_Somnr1 小时前
电机驱动学习以及闭环控制和硬件连接
嵌入式硬件·学习
学编程的闹钟1 小时前
75【虚拟主机和ftp】
学习
松涛和鸣1 小时前
24、数据结构核心:队列与栈的原理、实现与应用
c语言·开发语言·数据结构·学习·算法
可可苏饼干1 小时前
Docker命令与知识点归纳
运维·学习·docker·容器