這是我的主要課程:-import io.*;import processors.*;import utilities.*;import java.util.Scanner;import java.io.IOException;public class Main{ public static void main(String[] args) { AbstractCalcIO cio = null; //read properties file to know which type of operation needed. //then create appropriate class based on that. try { String opm = PropertyReader.getProperty("config.properties","opmode"); System.out.println("Got input class name: "+opm); //get the class object from the name of the input class Class c = Class.forName(opm); //then cast it to AbstractCalcIO and then assign it to cio object Object obj = c.newInstance(); cio = (AbstractCalcIO)obj; if(cio != null) { cio.startOperations(); } } catch (Exception ex) { System.out.println(ex); } }}在這個項目中,我使用抽象類、3-IO 類進行輸入控制、異常類等。這里我使用反射來避免代碼重復。這里還有一個控制功能的屬性文件。但是在我使用反射的主類中,我收到了一個通知。出于這個原因,我的項目文件沒有被編譯。我認為它發生在 java 版本上,我使用 javac 10.0.2。那么,解決方案是什么?在主類中,反射代碼部分是:- Class c = Class.forName(opm); //then cast it to AbstractCalcIO and then assign it to cio object Object obj = c.newInstance(); cio = (AbstractCalcIO)obj;屬性文件是:-datafile=E:\\java\\calcproject\\cdata.txtopmode=io.CalcIOSinglecalcmode=sc所以,最后我收到了這個通知:-E:\java\calcproject>javac Main.javaNote: Main.java uses or overrides a deprecated API.Note: Recompile with -Xlint:deprecation for details.解決方案將針對此問題:- 對于 Java 版本 10.0.2,將使用默認構造函數。 Class<?> c = Class.forName(opm); //here need to use default constructor Constructor<?> cons = c.getDeclaredConstructor(); Object obj = cons.newInstance(); cio = (AbstractCalcIO)obj;
1 回答

忽然笑
TA貢獻1806條經驗 獲得超5個贊
該Class.newInstance
方法繞過對默認構造函數的調用,因此可能會拋出異常(不好的做法)。這已經不再被警告了。閱讀 javadoc。
所以使用默認(無參數)構造函數:
Object obj = c.getConstructor().newInstance();
添加回答
舉報
0/150
提交
取消