草庐IT

Incident_Collection

全部标签

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 - 如何有条件地替换 Collection 中的值,例如 replaceIf(Predicate<T>)?

如果List或Collection中的值为null,是否有任何简单的方法可以替换该值?我们总能做到list.stream().filter(Objects::nonNull);并可能将0添加回列表。但我正在寻找的是类似list.replaceIf(Predicate)的API. 最佳答案 这只适用于List,不适用于Collection,因为后者没有替换或设置元素的概念。但是给定一个List,使用List.replaceAll()方法很容易做你想做的事情:Listlist=Arrays.asList("a","b",null,"c"

java - invokeAll() 不愿意接受 Collection<Callable<T>>

我不明白为什么这段代码不能编译ExecutorServiceexecutor=newScheduledThreadPoolExecutor(threads);classDocFeederimplementsCallable{....}...Listlist=newLinkedList();list.add(newDocFeeder(1));...executor.invokeAll(list);错误消息是:ThemethodinvokeAll(Collection>)inthetypeExecutorServiceisnotapplicableforthearguments(List)

java - 集合 - Iterator.remove() 与 Collection.remove()

根据太阳,"Iterator.removeistheonlysafewaytomodifyacollectionduringiteration;thebehaviorisunspecifiediftheunderlyingcollectionismodifiedinanyotherwaywhiletheiterationisinprogress."我有两个问题:是什么让这个操作“Iterator.remove()”比其他操作更稳定?如果“Collection.remove()”方法在大多数用例中都没有用,他们为什么要提供该方法? 最佳答案

java - MongoDB java 驱动程序可以在分片环境下执行 db.collection.group()

正如Mongodb手册中提到的,“db.collection.group()方法不适用于分片集群。在分片环境中使用聚合框架或map-reduce。”但是今天,我惊讶地发现它可以在Java驱动程序中运行。在我的测试中,分片集合称为“垃圾邮件”,其中包含4,001,633个文档。它分为7个分片。集合中的每个文档都有这样的格式。shard1:PRIMARY>db.spams.findOne(){"IP":"113.162.134.245","_id":ObjectId("4ebe8c84466e8b1a56000028"),"attach":[],"bot":"Lethic","charse

java - TreeMap Collection View 迭代器时间复杂度?

HashMap的所有3个CollectionView迭代器的时间复杂度(myHashMap.entrySet().iterator().next()和myHashMap.keySet().iterator().next()和myHashMap.values().iterator().next())在javadoc中有详细记录,它是O(n+c)对于所有这3个迭代器(n是映射的数量,c是哈希表中存储桶的物理数量的容量)。但是3个相应的TreeMapCollectionView的相应3个迭代器呢?官方javadoc中什么也没说。它们的复杂性是什么?我确实查看了SE8源代码,但我无法从那里做出

具有泛型方法和子类的 Java Collection

我有以下集合类,它包含一个方法,用于对映射中的元素进行分组,其中每个值都具有调用它的类的类型classTaskCollectionextendsHashSet{Map>groupBy(FunctiongroupingFunction){returnthis.stream().collect(Collectors.groupingBy(groupingFunction,Collectors.toCollection(this.collectionConstructor())));}Supplier>collectionConstructor(){returnTaskCollection:

java - Collection 内容从未在 Intellij IDEA 中更新警告

我创建了一个简单的Counter类:publicclassCounterextendsHashMap{publicCounter(){}publicvoidincrease(Tkey){put(key,getOrDefault(key,0l)+1);}}在我的代码中,我调用了increase()方法,然后使用Map方法访问数据,例如Countercounter=newCounter();for(Integeri:...somecollection...)counter.increase(i);Intellij使用警告颜色突出显示counter的声明(最后一段的第一行),工具提示消息显示