草庐IT

collection_check_boxes

全部标签

具有元素超时的 Java Collection 实现

是否有一些支持元素过期的集合实现。例如:CollectioncachedUsers=newExpirableList(10000);在哪里publicExpirableList(finallongtimeout){...}在给定时间后(在这个特定示例中为10000ms),添加的元素将从集合中删除。通过使用它,我们将防止我们的cachedUsers集合溢出。 最佳答案 是的,Guava支持定时过期的缓存。参见GuavaExplained'spageoncaches.另一种方法是LRU(最近最少使用)缓存,它在插入新元素时处理最早访问的

java - 2个系列之间的区别? (collection1 中的元素,但不在 collection2 中)

在Java中(也许使用Guava?),是否提供了一些方法来获取两个Collection的差异,例如一个List和一个Set没有修改这些Collection之一(否则会有collection1.全部删除(集合2)?在Guava中有Sets.difference(set1,set2),但它只适用于Set,不适用于任意集合。感谢任何提示! 最佳答案 您可以使用内置的Predicate过滤第一个Collection:Collections2.filter(c1,Predicates.not(Predicates.in(c2))它适用于任何类

java - 泛型:无法从 Collections.emptyList() 转换为 List<String>

为什么publicListgetList(){if(isMyListOKReady())returnmyList;returnCollections.emptyList();}编译很好,但是对于publicListgetList(){returnisMyListReady()?myList:Collections.emptyList();}Eclipse说"Typemismatch:cannotconvertfromListtoList"? 最佳答案 您需要注意空列表的类型安全。所以像这样返回空字符串列表publicListgetL

java - 如何根据 Collection 值的大小对 Map 进行排序?

我有一个像这样的HashMap:Map>map=newHashMap();map.put("USA",Arrays.asList("CA","IA","IL"));map.put("India",Arrays.asList("MUM","CAL"));map.put("Canada",Arrays.asList("TOR"));我想根据列表值的大小对map进行升序排序。我该怎么做?在这种情况下,我想订购加拿大、印度、美国的key。 最佳答案 HashMap没有保证的迭代顺序,因此您需要收集到LinkedHashMap为了使排序有意义

java - 使用 Collection.stream 按特定属性动态分组

我正在尝试使用Java8Collection-Stream按多个属性对对象列表进行分组。这很好用:publicclassMyClass{publicStringtitle;publicStringtype;publicStringmodule;publicMyClass(Stringtitle,Stringtype,Stringmodule){this.type=type;this.title=title;this.module=module;}}Listdata=newArrayList();data.add(newMyClass("1","A","B"));data.add(new

java - 使用 Collection 接口(interface)创建 ArrayList 对象的多态性有什么好处?

我研究了多态性,了解到它可以像下面这样进行动态方法绑定(bind)。假设类Animal是抽象类。publicclassAnimalReference{publicstaticvoidmain(Stringargs[])Animalref//setupvarforanAnimalCowaCow=newCow("Bossy");//makesspecificobjectsDogaDog=newDog("Rover");//nowreferenceeachasanAnimalref=aCow;ref.speak();ref=aDog;ref.speak();}我曾经像这样创建ArrayLis

java - 跳棋游戏 : Not Error Checking Correctly?

我正在为一项作业制作跳棋游戏。除了一件奇怪的事情外,整个事情都按照它应该的方式进行。这是我的董事会:我通过给出源行和列,然后是目标行和列来移动。move(intsrcR,intsrcC,intdestR,intdestC)如果我尝试将一block移动到无效点(不是对角线),我应该打印出一个错误。因此,如果我尝试从52->42移动一block,它会给我一条错误消息。if(destR==srcR+1||destR==srcR-1&&destC==srcC+1||destC==srcC-1){//codecodecode}elsemessage="InvalidMove!Canonlymov

java - 为什么在方法重载中加宽比 Boxing 和 var-args 都好?

我正在准备SCJP考试,在研究扩展部分时,它给出了扩展在重载方面胜过Boxing和Var-args,但没有明确的解释。尝试搜索但没有得到更好的答案。我得到的一个答案是因为编译器在选择较新的样式之前先选择较旧的样式。但我不相信。编辑:我知道加宽比装箱和可变参数更受欢迎。但为什么是我的问题。其中我知道一个。任何其他原因。 最佳答案 是的,出于兼容性要求,编译器“选择较旧的样式而不是较新的样式”。想象一下,一些在Java5出现之前编写的代码,在Java5下编译时突然发生了行为变化!那会很糟糕。扩展转换自Java诞生以来就已存在,但自动装箱

带有数组的 Java Collections.rotate() 不起作用

我有以下Java代码:importjava.util.Arrays;importjava.util.Collections;publicclassTest{publicstaticvoidmain(String[]args){int[]test={1,2,3,4,5};Collections.rotate(Arrays.asList(test),-1);for(inti=0;i我想让数组旋转,但是我得到的输出是12345这是为什么?还有其他解决方案吗?编辑:所以这是可行的:importjava.util.ArrayList;importjava.util.Collections;imp

Java 同步块(synchronized block)与 concurrentHashMap 与 Collections.synchronizedMap

假设如果有一个同步方法并且在该方法中,我会像这样更新一个hashmap:publicsynchronizedvoidmethod1(){myHashMap.clear();//populatethehashmap,takesabout5seconds.}现在当method1正在运行并且hashmap正在重新填充时,如果有其他线程试图获取hashmap的值,我假设它们会被阻止?现在不使用sync方法,如果我像下面这样将hashmap更改为ConcurrentHashMap,会有什么行为?publicvoidmethod1(){myConcurrentHashMap.clear();//p