gpt4 book ai didi

performance - 访问配置属性的成本是多少?

转载 作者:行者123 更新时间:2023-12-02 21:53:40 26 4
gpt4 key购买 nike

我正在开发一个 Scala 应用程序,它会以 10 分钟的间隔扫描一些文件夹。在我的类(class)中,我创建了大约 12 个全局变量,这有点奇怪,因为有些变量在异常点仅使用一次。

我想知道使用成本是多少:

configuration.getString("value")

每次都创建一个全局变量,例如:

private lazy val inputPath = configuration.getString("main.directory")

就性能而言,什么更好?仅在必要时调用或创建惰性全局变量?

提前致谢。

最佳答案

configuration.getString("value") 非常便宜。配置将在启动时读取并解析一次,然后将值存储在 java Map 中。因此,基本上调用 getString 可以归结为在 HashMap 中进行查找。这当然比共享变量更昂贵,但仍然具有恒定的复杂度 O(1)。尤其是当您每 10 分钟仅调用几次 getString 时,应该没问题。

我所指的实现可以在 sources of typesafe/config on GitHub 中找到。第 30 行是存储值的映射。

<小时/>

更新:今天早上我想到了你的问题,我突然想到为什么调用 getString 而不是使用初始化共享变量是一个坏主意值(value)。我没有立即想到它,因为它与性能无关:

getString 有副作用,即当配置值不存在时它可能会引发异常 - 例如,您的配置文件可能已损坏。由于通常没有针对此类异常的恢复策略,因此最好在启动时处理这些潜在的故障,而不是在节目开始几十分钟后无人再观看时处理。

在您的问题中,您使用了 lazy val 作为替代方案,它会遇到同样的问题,因为它只会在需要时进行评估。因此,我认为您应该在程序开始时将所有配置值读取到 val 中!

private val inputPath = configuration.getString("main.directory")

如果您使用后备值并且 100% 确信不会有异常(exception),这当然不适用。

关于performance - 访问配置属性的成本是多少?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26381152/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com