草庐IT

utility-method

全部标签

java - java.util.Map 条目集的问题

我在使用以下代码时遇到了一个奇怪的问题。Mapmap=newHashMap();for(Entryentry:map.entrySet()){//}而下面的代码无法编译。Mapmap=newHashMap();for(Entryentry:map.entrySet()){//compileerrorhere//}有什么线索吗? 最佳答案 entrySet方法签名是Set>entrySet()所以只能引用Map.Entry如果您像在第一个示例中那样在声明中声明了泛型类型。在第二个中,您使用的是原始类型,所以它本质上是SetentryS

Java 枚举 : Implementing methods After Declaration?

考虑下面在枚举中实现方法的简单示例。这种方法的一个问题是,当您有很多枚举实例时,您无法再在视觉上将它们作为一个列表一次全部看到。也就是说,如果我们有很多玩具,我希望在一个长列表中一起看到“DOLL、SOLDIER、TEDDYBEAR、TRAIN、ETC”,然后在该列表之后我可以实现任何需要的方法,例如在枚举本身中是抽象的方法。有什么办法吗?或者您是否必须在声明各个枚举实例时实现这些方法,如下例所示?publicenumToy{DOLL(){@Overridepublicvoidexecute(){System.out.println("I'madoll.");}},SOLDIER(){

java - Javadocs '#' 中 '{@link #method}' 的用途是什么?

Javadoc链接标记中的散列#的用途是什么?/**Call{@link#method}todofoo.*/ 最佳答案 Javadoc使用#作为类和方法/构造函数签名或字段名称之间的分隔符,以避免模棱两可的链接。Javadoc@link和@see标签可用于引用包、类和类中的特定方法/构造函数或字段。这可能并不明显,但拥有例如包“a.b”中的类“c”和包“a”中的类“b”在同一项目中具有名为“c”的字段。指向“packagea.b,classc”的Javadoc链接将写为a.b.c,而指向“packagea,classb,fieldc

Java 8 : When the use of Interface static methods becomes a bad practice?

从Java8开始,我们可以在接口(interface)中使用默认方法和静态方法。常量接口(interface)模式是对接口(interface)的不良使用,称为常量接口(interface)反模式。>EffectiveJava,第17项:Theconstantinterfacepatternisapooruseofinterfaces.Thataclassusessomeconstantsinternallyisanimplementationdetail.Implementingaconstantinterfacecausesthisimplementationdetailtolea

java - 如何在 java.util.concurrent.atomic 包中定义的类中实现原子性?

我正在浏览java.util.concurrent.atomic.AtomicInteger的源代码,以了解该类提供的原子操作是如何实现原子性的。例如AtomicInteger.getAndIncrement()方法源码如下publicfinalintgetAndIncrement(){for(;;){intcurrent=get();intnext=current+1;if(compareAndSet(current,next))returncurrent;}}我无法理解在无限循环中编写操作序列的目的。它在Java内存模型(JMM)中是否有任何特殊用途。请帮我找到一个描述性的理解。提

java - Methods.class 中的代码重用 vs 策略模式和依赖注入(inject)

关闭。这个问题需要更多focused.它目前不接受答案。想改善这个问题吗?更新问题,使其仅关注一个问题editingthispost.2年前关闭。ImprovethisquestionStatus:Fendy和GlenBest的回答是同样可以接受并受到我的尊重,但既然可以接受并给予赏金,我选择Fendy的答案。Scenario:如果我有一些代码有多次重复使用在多类(很少有明显的微小参数更改)和并发线程,采用哪种方法?必须重用的代码可以是任何理智的东西(适当注意静态和非静态上下文以及方法制作技术)。它可以是一个算法,一个做连接、操作、关闭的数据库方法。任何事物。创建一些类,如MyMeth

java - 基于其中元素数量的 java.util.List 的异常行为

这个问题在这里已经有了答案:WhyisaConcurrentModificationExceptionthrownandhowtodebugit(8个答案)关闭3年前。我知道如果在某些线程使用迭代器遍历集合时更改集合,iterator.next()将抛出ConcurrentModificationException。.但它会根据列表中元素的数量显示不同的行为。我尝试了一个代码片段,其中我在for-each循环中遍历了一个列表,并在遍历之间使用列表的remove()方法从列表中删除了一个元素。理想情况下,它应该在这种情况下抛出ConcurrentModificationException

java.lang.IllegalAccessError : tried to access method com. google.common.collect.MapMaker.makeComputingMap();来自 WeldMessageConveyor

当我尝试在weblogic12上部署我的Web应用程序时出现以下异常:weblogic.application.ModuleException:java.lang.IllegalAccessError:triedtoaccessmethodcom.google.common.collect.MapMaker.makeComputingMap(Lcom/google/common/base/Function;)Ljava/util/concurrent/ConcurrentMap;fromclassorg.jboss.weld.logging.WeldMessageConveyoratw

java - 将字符串转换为 java.util.Stream<Character>

有时我想对字符串中的每个字符做一些简单的事情。不幸的是,因为字符串是不可变的,所以除了循环遍历字符串之外没有好的方法,这可能会非常冗长。如果您改用Stream,则可以做得更短,只需一两行。有没有办法转换String进入Stream? 最佳答案 您可以使用chars()CharSequence中提供的方法自String类实现此接口(interface),您可以访问它。chars()方法返回IntStream,所以你需要把它转换成(char)如果您想转换IntStream至Stream例如publicclassFoo{publicsta

Java 反射 : Invoking Setter and Getter method for collection type Object

我有两个不同的用户定义对象包.....1)ws.lender.dto(allObjectsexistsinthispackagearesourceside).2)copl.com.dto(allObjectsexistsinthispackagearedestinationside).两侧的对象层次结构和对象名称不同。我想按字段将源端对象复制到目标端对象字段或通过使用反射的getter和setter。例如源端对象packagews.lender.dto;@XmlAccessorType(XmlAccessType.FIELD)@XmlType(name="CustomerAddress