首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Emacs中使用obarray而不是散列表有什么好处?

在Emacs中使用obarray而不是散列表有什么好处?
EN

Stack Overflow用户
提问于 2014-08-08 17:35:14
回答 1查看 916关注 0票数 10

我有一个Emacs程序,它需要跟踪一组字符串,使用它们来完成,并测试其他字符串的成员资格。在大多数没有内置set类型的语言中,我会使用带有虚拟t1值的字典或哈希表,但我突然意识到,Elisp的obarray类型也可以达到这个目的,internintern-softunintern取代puthashgethashremhash

(我知道cl-lib函数作为集合在列表上操作,但是这些函数与这个问题并不特别相关,它只需要一个集合成员资格测试)。

在现代Emacs中使用obarray而不是散列表是否有任何优势(在速度、内存使用或其他方面),还是除了主符号表之外,obarray更像是Emacs Lisp有单独哈希表类型之前遗留下来的?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-08-09 01:35:20

因为这两种工作,在很大程度上这是一个品味或性能的问题。

就内存使用情况而言(以单词计),obarray使用一个固定大小N的数组加上每个条目一个符号(大小为6),而哈希表的大小大约为每个元素5+稍多一点。所以从记忆上讲,这是一次清洗。

就速度而言,我不知道有谁费心测量它,所以它可能也不是一个大问题。

这是味觉问题。FWIW,我更喜欢提供更多选项的哈希表;在我看来,数组在很大程度上是一个历史上的意外。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25209134

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档