1

有什么方法可以获取由其他代码创建的缓存的底层键和值类型定义?此时我只知道缓存名称。我没有关于如何创建缓存的任何其他信息。

IgniteCache<K, V> dataCache = ignite.cache("dataCache");

我需要在上面的行中获取 K 和 V 的类型。

我会将 CacheEntryListener 附加到缓存中,并且我需要访问缓存的值部分中的字段。我该怎么做呢?有什么方法可以从侦听器方法中获得的 CacheEntryEvent 事件中访问类型信息?

4

1 回答 1

2

Ignite 缓存没有任何底层类型定义,它可以保存任何类型的数据。泛型只是为了您的方便。

例如,您可以这样做:

IgniteCache<String, String> sCache = ignite.createCache("foo");
sCache.put("1", "2");

IgniteCache<Integer, Integer> iCache = ignite.cache("foo"); // same cache
iCache.put(1, 2);

IgniteCache<Object, Object> oCache = ignite.cache("foo"); // same cache
oCache.get(1);  // 2
oCache.get("1");  // "2"

但是,不建议这样做。

每个缓存一个类型是推荐的方法:您的应用程序逻辑应确保每个命名缓存仅适用于特定数据类型。

于 2017-09-25T10:00:19.790 回答