- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对从 ets 表中选择的性能进行了一些测试,并注意到了奇怪的行为。例如,我们有一个简单的 ets 表(没有任何特定选项),它存储键/值 - 一个随机字符串和一个数字:
:ets.new(:table, [:named_table])
for _i <- 1..2000 do
:ets.insert(:table, {:crypto.strong_rand_bytes(10)
|> Base.url_encode64
|> binary_part(0, 10), 100})
end
:ets.insert(:table, {"test_string", 200})
test_string
从 ets 表多次并测量每个选择的时间:
test_fn = fn() ->
Enum.map(Enum.to_list(1..10_000), fn(x) ->
:timer.tc(fn() ->
:ets.select(:table, [{{:'$1', :'$2'},
[{:'==', :'$1', "test_string"}],
[:'$_']}])
end)
end) |> Enum.unzip
end
Enum.max(timings)
查看最大时间它将返回一个值,该值大约是所有其他选择的 10 倍。因此,例如:
iex(1)> {timings, _result} = test_fn.()
....
....
....
iex(2)> Enum.max(timings)
896
iex(3)> Enum.sum(timings) / length(timings)
96.8845
最佳答案
match_spec
,select/2
的第二个参数正在使它变慢。
根据对这个问题的回答
Erlang: ets select and match performance
In trivial non-specific use-cases, select is just a lot of work around match.
In non-trivial more common use-cases, select will give you what you really want a lot quicker.
set
的表或
ordered_set
键入,要根据键获取值,请改用 lookup/2,因为它要快得多。
def lookup() do
{timings, _} = Enum.map(Enum.to_list(1..10_000), fn(_x) ->
:timer.tc(fn() ->
:ets.lookup(:table, "test_string")
end)
end) |> Enum.unzip
IO.puts Enum.max(timings)
IO.puts Enum.sum(timings) / length(timings)
end
0
0.0
16000
157.9
关于performance - ets select 的性能下降,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58640319/
我一直在学习如何使用 ets,但困扰我的一件事是,偶尔*,ets:match 会抛出一个错误的参数...而且,从他们开始,所有后续调用(甚至之前有效的调用)也会抛出一个错误参数: > ets:matc
我正在尝试使用指数平滑方法创建预测,但得到错误“非季节性数据”。这显然不是真的 - 请参阅下面的代码。 为什么我收到这个错误?我应该使用不同的函数(它应该能够执行简单的、双重的、阻尼趋势的、季节性的、
I'm writing a program using Elixir and I have a very strange error.我正在用长生不老药编写程序,我有一个非常奇怪的错误。 I
I'm writing a program using Elixir and I have a very strange error.我正在用长生不老药编写程序,我有一个非常奇怪的错误。 I
我在 erlang 中使用 ets:select 有一个奇怪的行为。 我获得了正确的 select 语句(下面的 4 和 5),然后在我的语句中出错(下面的 6),然后我再次尝试与 4 和 5 中相同
如果我想将 ETS 表用于共享状态,是否有任何已建立的机制来等待插入 ETS 表? 我知道 mnesia 支持表事件,我在想一个类似的机制对普通 ETS 很有用,这样一个进程就可以等待它需要的数据被加
ets 包的delete_object 的运行时间是多少?鉴于有 n 个条目具有相同的键 k,delete_object 的运行时间是否为 O(n)或者O(1)?如果确实是 O(1),lookup 操
我们想知道如何有效地查找两个 ets 表之间的相互元素,我们尝试了 ETS 和 QLC 模块,但不知道如何做到这一点,我们在 [bag] 选项上使用 ets,这意味着同一个键有多个值。 我们正在寻找最
ETS set 是否保证元组的内部顺序与其插入顺序相同?例如:我通过每秒插入一个元组来保留日志,时间戳是关键。在此示例中,set 是否保证元组按键排序? 我知道ordered_set会做我希望的事情,
具体来说,:ets.tab2list 和 :ets.file2tab。这些函数是否“快照”表状态,或者其他操作是否可以在这些函数完成时交错读取和写入? 最佳答案 基于文档 here : Functio
我是 Erlang 新手。我有一个关于 ets 表的问题。 我有两个 ets 表,我需要从两个表中插入或删除值。 insert(V) -> ets:insert(table_test,V),
我使用 elang ets 表作为一个简单的缓存。我想使用一个进程来扫描表并删除过期元素(多个)。 使用 ets:foldl expire_table_example() -> Tab = ets:n
我在使用 ets:match 时遇到问题。在下面的代码中,我希望 ets:match 返回 1 个找到的值,但没有返回任何值。为什么? 1> T = ets:new(xxx, []). 16400 2
我在一个进程中创建了 ETS 表,我想在另一个进程中使用它。我如何在第二个过程中“打开”ETS 表?在手册页中找不到好的功能。 最佳答案 您必须使用“named_table”和“public”选项创建
我通过 elixir 使用 ets 作为一个简单的内存持久层来存储和检索键,以及偶尔的 foldl,这涉及减少许多具有不同值的重复键。我正在使用包选项。 是否有一种简单的,也许是 O(1) 的方法来检
我正在考虑在一个新的 Elixir 项目中使用 Erlang 的 ETS 作为用户搜索的缓存。根据用户输入,系统将使用昂贵的第三方 API 进行查找。 为了避免对相同的用户输入进行重复调用,我打算在外
在调试使用信号量进行跨进程同步的应用程序时,我偶然发现了使用PowerShell代替“其他”进程的想法。在PowerShell中执行以下操作可以正常工作: // In C# application:
我对从 ets 表中选择的性能进行了一些测试,并注意到了奇怪的行为。例如,我们有一个简单的 ets 表(没有任何特定选项),它存储键/值 - 一个随机字符串和一个数字: :ets.new(:table
我有一些这样的代码: Table = ets:new(table, [bag]), true = ets:insert(Table, {bucket_1, some_value_1}), true =
假设我有一个 ets 表,例如: I = ets:new(mytable, [named_table, set]). ets:insert(I, {10,{10, 4 ,"description"})
我是一名优秀的程序员,十分优秀!