我有过的快速扫描番石榴API,它提供了新的集合类型(Multimap
以及BiMap
例如出现有用),我想包括在项目(S)在我工作的图书馆。
但是,如果它们对图书馆没有太大好处,我也不愿意将它们包括在内,并且学习这些功能会浪费宝贵的时间。
您是否在项目中包括了Guava库,并以任何意想不到的方式证明了它有用吗?您将来会一直使用它吗?它的主要好处/节省时间是什么?它的隐藏功能是什么?
我有过的快速扫描番石榴API,它提供了新的集合类型(Multimap
以及BiMap
例如出现有用),我想包括在项目(S)在我工作的图书馆。
但是,如果它们对图书馆没有太大好处,我也不愿意将它们包括在内,并且学习这些功能会浪费宝贵的时间。
您是否在项目中包括了Guava库,并以任何意想不到的方式证明了它有用吗?您将来会一直使用它吗?它的主要好处/节省时间是什么?它的隐藏功能是什么?
Answers:
认真地说,番石榴中的所有内容都很有用。我使用它已经有一段时间了,并且仍然总是发现我可以用它做的新事情,它比手工完成需要更少的代码。
有些其他人并没有真正提到我喜欢的东西:
Multimap
s很棒。任何时候,您都可以使用Map<Foo, Collection<Bar>>
,代替,而是使用multimap来节省大量繁琐的工作,以检查映射到键的现有集合,如果不存在则创建并添加它。Ordering
对于构建Comparator
行为完全符合您想要的样式非常有用。Maps.uniqueIndex
和Multimaps.index
:这些方法采用Iterable
和,Function
并构建一个ImmutableMap
或ImmutableListMultimap
,Iterable
通过将函数应用于每个的结果来索引或中的值。因此,使用检索项目ID的功能,您可以在一行中按项目ID为项目列表编制索引。filter
,transform
等等。尽管为Function
s和Predicate
s 使用类非常冗长,但我发现这很有用。我举一个例子来说明这一点。ComparisonChain
是一个很小的,易于忽略的类,当您要编写一个比较方法来连续比较多个值并在找到第一个差异时应返回时,该类很有用。它消除了所有繁琐的工作,仅需几行链式方法调用。Objects.equal(Object,Object)
-空安全等于。Objects.hashCode(Object...)
-一种基于类的多个字段获取哈希码的简便方法。Objects.firstNonNull(Object,Object)
-如果第一个值为null,则减少获取默认值的代码,尤其是如果第一个值是方法调用的结果时(您必须以常规方式将其分配给变量)。CharMatcher
已经提到过,但功能非常强大。Throwables
使您可以使用throwables做一些不错的事情,例如,Throwables.propagate
如果throwable是a RuntimeException
或an Error
,则将其重新抛出,然后将其包装为a RuntimeException
,否则将其抛出。我当然可以继续,但是我必须开始工作。=)无论如何,尽管我在这里列出了一些我喜欢的东西,但事实是番石榴中的所有内容在某些情况下还是有用的。它的很多是非常有用的。使用时,您会发现更多用途。不使用它会感觉有点像将一只手绑在背后。
ComparisionChain
。
我已经在Google内部有效使用Guava了两年了,这真是太好了。
我特别喜欢的部分是:
Charsets.*
-如此简单,如此有用Splitter
/Joiner
Preconditions
我最初将其用于收藏速记。例如,代替:
Map<String, Map<Long, List<String>>> map = new HashMap<String, Map<Long, List<String>>>();
你可以这样做:
Map<String, Map<Long, List<String>>> map = Maps.newHashMap();
填充地图也很容易:
ImmutableMap<String,String> map = ImmutableMap.of("key1", "value1", "key2", "value2");
现在,我发现了Guava中存在的其他有用工具。例如,CharMatcher类允许您匹配字符序列。你可以做:
CharMatcher.inRange('a','z').or(inRange('A','Z'));
要么
String phoneNumber = CharMatcher.DIGIT.retainFrom("my phone number is 123456789");
CharMatcher的precomputed()方法(source)是前几天我偶然发现的一个不错的“隐藏功能”。
它实际上只是一种优化,它创建了一个查找表(使用位数组),然后简单地查找字符以查看它们是否“匹配”。
这是一种使用库时可以利用的隐式优化,您可能没有在自己的代码中想到过自己。
当然,如果您创建了一个计划多次使用的复杂CharMatcher,则必须记住调用precomputed()方法,例如:
CharMatcher complexMatcher = CharMatcher.anyOf("cat")
.or(CharMatcher.DIGIT)
.or(CharMatcher.WHITESPACE)
.precomputed();
Google Guava是一个实用程序库,因此我怀疑其中是否有杀手级。关于实用程序的全部内容是,您几乎在每个项目中都使用了它。我不记得我做过的任何不使用Java集合的项目。事实是,Google Guava的收集实用程序很棒,应该在Java SDK本身中。
我写了三篇有关Google Guava上的类的文章:
CheckedFuture
:http : //blog.firdau.si/2010/07/07/guava-using-checkedfuture/ListenableFuture
:http : //blog.firdau.si/2010/07/05/guava-using-listenablefuture/ComputingMap
在Google Collection(现在称为Guava)上http://blog.firdau.si/2009/11/13/computing-map-on-google-collections/这还不是全部,番石榴还可以做很多其他事情。
绝对非常有用。几乎总是第一个添加到新项目中的库。
总体而言,图书馆的质量很高。该API经过深思熟虑,实现扎实。强烈推荐。
MapMaker现在提供有限的LRU缓存-这是隐藏在微小API后面的一些重要设备。这可能具有巨大的实用性,我仍然遍及所有代码。