草庐IT

some_collection

全部标签

java - 使用 openEntityManagerInView 仍然得到 "failed to lazily initialize a collection of role"

我试图将我的一个实体返回到JSP页面,但收到以下错误“无法延迟初始化角色集合”。我已经添加了openEntityManagerInView过滤器(假设它允许实体管理器在View中保持打开状态?)但仍然出现此错误。我的应用程序是使用没有xml的javaconfig配置的。下面是我的调度程序servelet。你可以看到我已经添加了openEntityManagerInView过滤器。知道这是为什么吗?我在stackoverflow上检查过类似的问题,但没有找到所提供的解决方案。publicclassDispatcherServletInitializerextendsAbstractAnn

java - hibernate/Ehcache : evicting collections from 2nd level cache not synchronized with other DB reads

我有一个使用JPA、Hibernate和ehcache的应用程序,以及Spring的声明式交易。数据库上的负载相当高,因此所有内容都被缓存以加快速度,包括Collection品。现在集合被单独缓存已经不是什么secret了来自拥有它们的实体,所以如果我删除一个作为此类元素的实体缓存集合,持久化一个应该是一个元素的实体,或者更新一个实体使得它从一个集合移动到另一个集合,我必须执行驱逐手工制作。所以我使用了一个hibernate事件监听器,它跟踪实体被插入、删除或更新并保存该信息以用于在Spring中注册的事务同步事务管理器采取行动。一旦事务已提交。现在的问题是很多时候,一些其他并发事务设

java - ArrayList 在 Java Collection Framework 内部是如何表示的?

我正在听RobertSedgewick在Coursera上的算法讲座。当Robert先生指出不能将泛型与数组一起使用时,我有点困惑,因为这是不允许的。但是CollectionFramework中的ArrayList在内部使用Arrays并且允许使用Generic数据类型。我的意思是说我们可以执行以下操作:ArrayListlist=newArrayList();他指出的一个hack是这样的:publicclassFixedCapacityStack{privateItem[]s;privateintN=0;publicFixedCapacityStack(intcapacity){s=

java - Collections.sort 没有对任何东西进行排序

我正在尝试以一种简短的方式对字符串数组进行排序。我正在尝试使用Collections.sort,但我不明白为什么它不对任何内容进行排序。代码:publicstaticString[]FishNamesSorted;.....Listnameslist=newArrayList();nameslist.toArray(FishNamesSorted);Collections.sort(nameslist,String.CASE_INSENSITIVE_ORDER);(){两种情况下的结果:紫罗兰网纹紫罗兰长尾紫罗兰假单胞菌科....为什么? 最佳答案

java - 我可以使用 Collection.size() 来替换这段代码中的计数器吗?

代码如下:publicclassLogService{privatefinalBlockingQueuequeue;privatefinalLoggerThreadloggerThread;privatefinalPrintWriterwriter;@GuardedBy("this")privatebooleanisShutdown;@GuardedBy("this")privateintreservations;//这是JavaConcurrencyinPractice一书的片段,我在想也许计数器reservations是不必要的,因为我们可以简单地使用queue.size()获取q

java - 什么时候需要 Some<E extends Some<E>> 而不是 Some<E extends Some>?

注意:这个问题与Enum无关,所以它不是重复的。Enum被迫只与自身比较,因为编译器生成类型参数,而不是因为java递归类型参数。我试图找到将类声明为的优势:publicclassSome>与声明为:publicclassSome我尝试提供返回E的方法和方法返回Some,复杂类层次结构中的不同交叉调用以及每次我试图删除额外的-没有出现新的错误/警告。你能告诉我一个方法来证明这个额外的的优势吗??由于JDK声明,我假设存在一个:>对SO上其他问题的回答例如:Withtheadditionalconstruct,youknowthatanyclassthatextendsEnumiscom

java - 为什么这么多方法使用 Collection 而不是 Iterable?

有了C#,我逐渐爱上了IEnumerable界面。在很多情况下,这就是您想要提供和接受的全部内容。此外,它在.Net库中也很有用。例如,您在List上有一个构造函数需要IEnumerable的类(class).我现在必须使用Java,自然想使用等效的Iterable界面。但是,似乎我真的不能在任何地方使用它。一切似乎都在使用扩展的Collection接口(interface)代替。为什么是这样?例如,您有ArrayList采用Collection的构造函数:Constructsalistcontainingtheelementsofthespecifiedcollection,inth

java - Guava/Google Collections 的向后兼容性如何?

我正在开发包含多个项目的大型应用程序,所有项目仍然使用GoogleCollections1.0。我想升级到Guava12。项目的测试覆盖率不是很好。有没有人有过类似的升级经验,有没有不兼容的地方?主要问题是什么? 最佳答案 这里是Guava贡献者。Guava12几乎完全向后兼容GoogleCollections,但极少数方法已经过了18个月的弃用期并被删除;见https://code.google.com/p/guava-libraries/issues/detail?id=836.也就是说,没有人应该仍然在使用GoogleColl

java - collection.stream().skip().findFirst()的效率

假设set是一个包含n元素的HashSet而k是一些int在0(含)和n(不含)之间。有人可以简单地解释一下当您这样做时实际发生了什么吗?set.stream().skip(k).findFirst();具体来说,这个的时间复杂度是多少?将spliterator()添加到Collection接口(interface)是否意味着我们现在可以比Java7更快地访问集合的“随机”元素? 最佳答案 当前的实现复杂度为O(k),更等同于:Iteratorit=set.iterator();for(inti=0;i当前的实现从不考虑顺序流的OR

java - java.util.Collections.contains() 如何比线性搜索执行得更快?

我一直在胡思乱想各种搜索集合、集合的集合等的不同方法。做了很多愚蠢的小测试来验证我的理解。这是让我感到困惑的一个(源代码在下面)。简而言之,我正在生成N个随机整数并将它们添加到列表中。该列表未排序。然后,我使用Collections.contains()在列表中查找值。我有意寻找一个我知道不会存在的值,因为我想确保整个列表空间都被探测到。我为这次搜索计时。然后我手动进行另一个线性搜索,遍历列表的每个元素并检查它是否与我的目标匹配。我也为这次搜索计时。平均而言,第二次搜索比第一次搜索花费的时间长33%。按照我的逻辑,第一次搜索也必须是线性的,因为列表是未排序的。我能想到的唯一可能性(我立