草庐IT

static-initializer

全部标签

java : non-static variable cannot be referenced from a static context Error

以下代码在变量con2上生成错误,提示“无法从静态上下文错误中引用非静态变量con2。”我在Google上搜索了一个解决方案他们建议变量尚未初始化以使方法可用。我是否错误地初始化了它?我也尝试过将内容更改为公开,但这也无济于事。importjava.io.*;importjava.net.*;importjava.sql.*;importjava.sql.CallableStatement;importjava.sql.ResultSet;importjava.sql.PreparedStatement;importnet.sourceforge.jtds.jdbcx.JtdsData

java - Java 中 C 的 "static"关键字等同于什么?

我想知道java中的等效关键字是什么,它可以执行与“C中的静态关键字”相同的功能。我想在java中进行递归,执行与C中的静态关键字相同的功能...请帮忙.. 最佳答案 C对static关键字有两种完全不同的用法,C++增加了第三种用法://Use1:declareavariableorfunctiontobelocaltoagivenmodule//Atglobalscope:staticintglobal_var;staticvoidfunc();在这种情况下,全局变量global_var和函数voidfunc()只能在声明它们的

java - @SpringBootTest 与@Sql : order of script execution and context initialization

我有在内存数据库上执行的集成测试。每个测试的签名大致如下所示:@RunWith(SpringRunner.class)@SpringBootTest@Sql("/clean-data-in-all-tables.sql")publicclassSomeTest{@TestpublicvoidshouldDoSomehting(){}}在测试上下文初始化期间,数据库模式由Hibernate重新创建:spring:jpa:hibernate:ddl-auto:create-drop我希望sql脚本在上下文初始化后执行,并在数据库模式生成后执行。然而,在某些情况下,clean-data-in

java - Spring SAML 示例应用程序返回 Could not initialize class org.apache.commons.ssl.TrustMaterial

我一直在尝试启动并运行SpringSAML示例应用程序,但已经苦苦挣扎了好几天,并且在互联网上搜索也没有成功。我已按照快速入门指南中的所有步骤操作....当我单击“开始单点登录”按钮时,我被重定向到SSOCircle,我登录,然后被重定向回示例应用程序,但它返回以下错误:Message:Couldnotinitializeclassorg.apache.commons.ssl.TrustMaterialStackTrace:java.lang.NoClassDefFoundError:Couldnotinitializeclassorg.apache.commons.ssl.Trust

java - ASM 5 : when initializing a ClassWriter, COMPUTE_MAXS 和 COMPUTE_FRAMES 有什么区别?

我是grappa的维护者.此包通过使用ASM生成一个扩展您的解析器类的类,在运行时从Java代码生成解析器。我已经从ASM4迁移到ASM5,从生成JVM1.5字节码迁移到生成JVM1.6字节码,现在我刚刚成功地让它生成JVM1.7字节码......除了我不知道为什么这是有效的。基本上,我做了以下事情:更改ClassWriter构造函数的参数;在此之前它是newClassWriter(ClassWriter.COMPUTE_MAXS),现在是newClassWriter(ClassWriter.COMPUTE_FRAMES)将每次调用.visit()方法的第一个参数从Opcodes.V1

java - 有什么办法可以保存 `static members` 的状态吗?

就像我们使用序列化保存实例变量的方式一样,有什么方法可以保存static成员的状态吗?如果在某种情况下,必须恢复静态成员的状态才能恢复某些内容,该怎么做? 最佳答案 我想到的最简单的选择是使用singleton而不是静态字段。单例对象可以序列化和反序列化,您可以管理它的生命周期,同时保留静态字段为您提供的“全局状态”(也就是说,全局状态是一件坏事,但这是另一个话题)否则-静态状态在类加载器的整个生命周期(这通常意味着JVM的生命周期)中得到保留。因此,如果你想持久化状态,在关闭时执行它并在类加载时恢复它是有意义的。Runtime.a

java - 如果在引用类之前不调用静态初始化程序,如何注册 java 类

我有一个由执行文件处理(比如搜索或其他)的类实现的接口(interface)。publicinterfaceFileProcessorInterface{publicvoidprocessFile(StringfileName);}然后我对每种文件类型都有不同的实现:publicclassTxtProcessorimplementsFileProcessorInterface{@OverridepublicvoidprocessFile(StringfileName){//dothework}}因此我有处理器的Utilizer,它有一个允许注册每个类的方法,如下所示:classUtil

Java编译器错误谜题: "inner classes cannot have static declarations" - except for simple types

在编写代码时,我遇到了一种奇怪的Java编译器行为。当编译类(下面的源代码)时,编译器在NULL类变量上发出错误(“内部类不能有静态声明”)。这符合预期!但是,零类变量不会产生错误。这个我不懂!为什么会有这种差异,它似乎允许在内部类中对简单类型进行静态声明,但不允许对对象进行静态声明。(javac-version:1.6.0_24)publicclassOuter{publicstaticfinalRunnableHELLO=newRunnable(){//NocompilererrorpublicstaticfinalintZERO=0;//Causescompilererror:"

java - 为什么 static final 在每次迭代中都比 new 慢

为什么代码片段A比代码片段B慢14倍?(在Windows764位上使用jdk1.8.0_60测试)代码片段A:importjava.awt.geom.RoundRectangle2D;publicclassTest{privatestaticfinalRoundRectangle2D.DoubleRECTANGLE=newRoundRectangle2D.Double(1,2,3,4,5,6);publicstaticvoidmain(String[]args){intresult=RECTANGLE.hashCode();longstart=System.nanoTime();for

java - org.hibernate.LazyInitializationException : could not initialize proxy - no Session, encore un fois

Foo看起来有这个:@ManyToManyprivateSetfavouritedBy;当用户有这个时:@ManyToMany(mappedBy="favouritedBy")privateSetfavourites=newHashSet();publicSetgetFavourites(){returnfavourite;}fooService有这个,在打开session时通过事务方法访问延迟加载的集合:@Transactional(readOnly=true)publicSetgetFavourites(Useruser){user=dao.get(User.class,user.