草庐IT

other_search_fields

全部标签

java - 为什么 private static field = new Singleton 在 Java 中不懒惰?

我看了很多关于Singleton的文章,其中大部分作者都说Java中Singleton的这种变体:publicclassSingleton{privatestaticSingletoninstance=newSingleton();privateSingleton(){}publicstaticSingletongetInstance(){returninstance;}}是不懒惰(然后是EAGER)。但我不明白为什么,Singleton()构造函数只会在Singleton类初始化时被调用。我知道几个可以触发类初始化的原因:将new与构造函数一起使用(但在这种情况下,构造函数是私有(p

java - reflect.Field.annotations 始终为空

我正在尝试使用反射和注释。出于某种原因,每当我向字段(或类或方法)添加注释并使用反射查看该字段时,我都会看到它的annotations字段为空。例如,这段代码:publicclassTest{publicstaticvoidmain(String[]args)throwsNoSuchFieldException,SecurityException{System.out.println(Test.class.getField("bl").getAnnotations().length);}@annopublicintbl;public@interfaceanno{}}打印0。顺便说一句,

java - Field 中原始 getter/setter 的目的是什么?

在Field中publicObjectget(Objectobj)方法的文档中类说Thevalueisautomaticallywrappedinanobjectifithasaprimitivetype.对于publicvoidset(Objectobj,Objectvalue)来说Iftheunderlyingfieldisofaprimitivetype,anunwrappingconversionisattemptedtoconvertthenewvaluetoavalueofaprimitivetype.所以我是对的,像getInt和setInt这样的特定原始getter和s

java - BeanWrapperFieldsetMapper 映射 PropertyEditor per field basis

我正在使用springbatch进行文件到数据库的处理,目前我正在使用PropertyEditors将分隔文件中的字符串转换为下面提供的某个对象。Map,PropertyEditor>editors=newHashMap();CustomDateEditordateEditor=newCustomDateEditor(newSimpleDateFormat("yyyy-MM-dd"),true);editors.put(Date.class,dateEditor);因此,如果我有一个日期字段,我将使用CustomDateEditor并成功解析给定的格式日期字符串。但是,如果我在同一文件

java - FindBugs - SE_BAD_FIELD 规则,为什么它会忽略 java.lang.Object?

来自SE_BAD_FIELD的描述:Non-transientnon-serializableinstancefieldinserializableclassThisSerializableclassdefinesanon-primitiveinstancefieldwhichisneithertransient,Serializable,orjava.lang.Object,anddoesnotappeartoimplementtheExternalizableinterfaceorthereadObject()andwriteObject()methods.Objectsofthi

java - Spring 数据 MongoDB : How ignore unique indexed field when Document is embedded in another one?

我有一个这样定义的Contract类:@DocumentpublicclassContract{@IdprivateStringid;@Indexed(unique=true)privateStringref;privateStringstatus="pending";//getter&setter&hashcode&equals&tostring...}我想随时间保存契约(Contract)状态,所以我创建了一个Version类,如下所示:@DocumentpublicclassVersion{@IdprivateStringid;privateContractcontract;pr

java - 试图了解 "both methods have same erasure, yet neither overrides the other"的情况

这个问题在这里已经有了答案:Methodhasthesameerasureasanothermethodintype(7个答案)关闭4年前。我正在尝试解决一个问题,我想出了这个解决方案(简化):packagehelp;publicclassProblem{privatestaticclassA{publicvoidfoo(Tt){}}privatestaticclassB{}privatestaticclassCextendsA>{publicvoidfoo(Tt){}}}它不会编译,因为“help.Problem.C中的foo(T)与help.Problem.A中的foo(T)冲突;

java - 好的设计 : How use fields of superclass

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Javaprotectedfieldsvspublicgetters如果我有B类扩展A并且在A中我有一些我也在B中使用的字段,最好使这些字段受到保护并从B类中调用它们或为此字段编写getter方法,因此使用此方法来自B级?(此字段在A的构造函数中设置)

java - Hibernate Search 不索引/重新索引实体

我正在尝试在我的项目中使用HibernateSearch(现在正在使用junit+dbunit编写测试),但是搜索查询没有返回任何结果。我昨天研究了这个问题并得出结论,问题是HibernateSearch不能很好地与dbunit@DatabaseSetup一起工作(与这个未回答的问题类似的问题:link)。我将介绍更多细节,但首先是我的实体类:@Entity@IndexedpublicclassUser{@Id@GeneratedValue(strategy=GenerationType.AUTO)@Column(name="userId")privateLongid;(...)@Co

java - SonarQube 误报鱿鱼 :S1450 for @Getter (lombok) annotated fields

我想我在使用@Getter时发现了误报来自ProjectLombok的注释.在下面的示例类中,我收到警告“仅用作方法中的局部变量的私有(private)字段应成为局部变量”(squid:S1450)。publicclassExample{@GetterprivateStringexampleField;//有人可以证实吗?是SonarQube规则中的错误还是我的类(class)或我对该规则或@Getter注释的理解有问题?为了完整起见:项目lombok注释或生成的方法在其他SonarQube规则中被正确识别。所以我认为我的设置很好。我还尝试将@Getter注释放在类级别,但我收到了同样