假如現有兩個API,AIPa,和APIb,兩個api定義的類,接口,功能均完全相同,但是有寫細微差別,比如說方法的參數類型不同,方法的返回值不同等等。
比如APIa中一個類A的方法為public int add(String a,String b)
比如APIb中的一個類A的方法為 public int add(int a,int b)
之前有一程序是使用APIa編寫的(現在只提供此程序的 class文件,不提供程序的源代碼,不允許修改程序的源代碼),現在要使這個程序能夠在APIb下能夠使用??
方法一不修改APIb的classes文件,而是修改應用程序的classes文件,將掃描原始應用程序的class文件,將class文件中用到APIa的方法轉換成APIb的方法??,這個應該不叫轉換,比如在程序中調用a.add("1","2")時,在方法調用前將方法棧中的字符串參數轉換成數字,使用javassist怎么來做,使用bcel怎么來做??
方法二不修改應用程序的classes文件,而是修改APIb的classes文件,是將APIb的接口形式轉換為APIa的形式,使用javassist重寫APIb的方法,對APIb的所有方法進行包裝成APIa的方法,然后使用重寫的APIb的classes文件來允許程序。這個使用javassist應該比較方便,使用becl?
這個就有點不方便了,如果APIb的類庫比較大的話,API間不一致的地方也比較多的話,都需要自己重寫,相當于重新包裝了這個APIb,需要修改APIb的classes文件,有可能其他程序要用到這個APIb。
還不太清楚,在仔細想想怎么來做,接下來的工作自己寫兩套簡單的API,然后試驗試驗。
剛開始想的是使用方法二來做,好像這個不太現實,應該是程序使用到了哪個方法,就對這個方法來進行修改,還是方法一好點。
再好好看看java虛擬機規范。。。
這個只是一個簡單問題的提出,而我實際要轉換的程序要比這個復雜,但是基本原理就這了。
tmd,花了一天多把java虛擬機規范看了好幾章,我都佩服自己的學習能力,他媽的為什么就找不到實習了?
posted on 2009-08-12 12:16
Frank_Fang 閱讀(433)
評論(0) 編輯 收藏 所屬分類:
bcel javassist