我有一个类,我有我的main方法,我在那里调用两个单例模式的静态getter调用。也就是说,我有2个类,它们都有静态块并且每个类都有getter。以下内容仅供参考。
public class RestAPIMain {
public static void main(String[] args) throws MalformedURLException, IOException, SAXException, XMLStreamException {
System.out.println("Starting main");
LinkedHashMap<String, String> urlresponses = URLResponse.getURLResponselist();
LinkedList<String> xmllist = XMLLoad.getXMLFiles();
System.out.println(xmllist);
上面的代码有getURLResponselist和getXMLFiles,其类使用静态块加载XML文件和Properties文件,然后使用List / Map使用getter存储和检索值,如下所示:
FILELOADING:
public class FileLoad {
public static Map<String, Object> jsonload;
public static Map<String, Object> executioncontrol;
static {
System.out.println("loading static for fileload");
URL path = FileLoad.class.getResource("FileLoad.class");
try {
Enumeration<URL> e = ClassLoader.getSystemResources("/resources/json/");
while (e.hasMoreElements()) {
URL u = e.nextElement();
String fileName = u.getFile();
File folder = new File(fileName);
File[] listOfFiles = folder.listFiles();
for (File file : listOfFiles) {
InputStream fis = new FileInputStream(file);
if (file.getName().equals("RestURLS.json")) {
jsonload = CommonUtil.jsonToMap(IOUtils.toString(fis, "UTF-8"));
} else if (file.getName().equals("RestExecution.json")) {
executioncontrol = CommonUtil.jsonToMap(IOUtils.toString(fis, "UTF-8"));
}
}
}
} catch (IOException e) {
e.printStackTrace();
} catch (Exception e1) {
e1.printStackTrace();
}
}
public static Map<String, Object> getJSONFiles() {
return jsonload;
}
public static Map<String, Object> getRestExecution() {
return executioncontrol;
}
PROPERTIESLOAD
public class PropertiesLoad {
private static Properties prop = new Properties();
public static LinkedHashMap<String, String> allkeyvalues = new LinkedHashMap<String, String>();
static {
System.out.println("loading static for properties");
InputStream ins;
try {
ins = new PropertiesLoad().getClass().getResourceAsStream("/resources/Rest.properties");
prop.load(ins);
} catch (FileNotFoundException e1) {
e1.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
public static String getPropValue(String key) {
String propkey = prop.getProperty(key);
return propkey;
}
public static LinkedHashMap<String, String> getAllKeysValues() {
String value = null;
String key = null;
for (Entry<Object, Object> keyvalues : prop.entrySet()) {
key = (String) keyvalues.getKey();
value = (String) keyvalues.getValue();
allkeyvalues.put(key, value);
}
return allkeyvalues;
}
}
URLResponse
public class URLResponse {
public static LinkedHashMap<String, String> urlresponses = new LinkedHashMap<String, String>();
@SuppressWarnings("unused")
public static LinkedHashMap<String, String> getURLResponselist() throws MalformedURLException, IOException {
LinkedHashMap<String, String> allkeyvalues = PropertiesLoad.getAllKeysValues();
for (String urlkey : allkeyvalues.keySet()) {
String urls = allkeyvalues.get(urlkey);
System.out.println(urls);
URL url = new URL(urls);
InputStream urlins = new URL(urls).openStream();
if (!(urlins.read() == -1)) {
String xmlresponse = IOUtils.toString(urlins, "UTF-8");
urlins.close();
urlresponses.put(urlkey, xmlresponse);
} else {
HttpURLConnection http = (HttpURLConnection) ((URL) url).openConnection();
int statusCode = http.getResponseCode();
// TODO:add log
}
}
// TODO:add log
return urlresponses;
}
}
URLResponse从Propertiesload调用getmethod,它通过静态块加载属性文件,文件加载也有静态块,然后main方法使用静态块来加载文件。
这里的观察是静态块是在调用main方法调用之后执行而不是在main方法开始执行之前执行的。静态块中的added print语句也表明控件首先进入main方法,从他们的移动到静态块和静态块执行。
我的需求是在类加载期间在main方法之前加载XML文件和Properties文件以及其他文件,并使用getter来检索我们存储它的集合,如singleton。此外,我读到该类首先加载,然后链接,然后初始化。因此,静态块在加载期间执行,但在我的情况下不会发生。
请指导我关于我的方法出错的地方以及它是如何发生的,所以在我的代码中,静态块在主方法调用之后执行。
答案 0 :(得分:0)
好吧,在Java中,静态块在类加载时执行。在您的情况下,删除您当前拥有的所有静态块并将它们放在方法中。然后在主类中创建一个静态块并执行必要的调用,这些调用需要在main方法启动之前完成。下面给出了一个示例代码。
package com.demo;
public class Sample {
public static void print(String msg){
System.out.println(msg);
}
}
package com.demo;
public class Test {
static{
Sample.print("Invokes Before Main ...");
}
public static void main(String[] args) {
System.out.println("Inside Main ....");
}
}
希望这会有所帮助。快乐的编码。