0

在我的 java Spring 应用程序中,我需要构建一些配置元数据的进程内/内存缓存,其结构如下:

Graph<String customerName, Map<String, JSONObject> customerMetadata>:

  "My Customer" "CustomerInfo":
                    {IngestionConfig:  {"data": "schema":{"fields"[]}}}
                "Asset"
                    {IngestionConfig:  {"data": "schema":{"fields"[]}}}
                "Invoice"
                    {IngestionConfig:  {"data": "schema":{"fields"[]}}}

问题:

哪种技术更适合此目的:Map、来自 Google Guava 的 ValueGraph、EhCache 或其他?

4

1 回答 1

1

这取决于。您是否希望您的缓存在特定时间后自行过期?您是否需要分发您的地图?它是只读的还是您打算在运行时更新它?如果它不是只读的,您的环境是单线程的还是多线程的?如果您不需要任何这些花里胡哨,并且如果它是只读的,我宁愿使用 Map(或任何包含 Java 的东西)。(这只是一个观点——我是一个极简主义的人。)

于 2016-10-28T14:45:23.193 回答