你知道如何增加KVM中的系統調用API 嗎,這裡向大家描述一下,不同的J2ME設備,也有不同的系統調用API以及它們的實現,相信本文介紹一定會讓你有所收獲。
J2ME KVM教程之如何增加KVM中的系統調用API
大家都曉得KVM是不支持Native函數調用的,如果要增加一些系統調用的API,那麼只能加到KVM內部。同時,不同的J2ME設備,也有不同的系統調用API以及它們的實現。我們從SUN那麼下載到原始的KVM源代碼,如何為其增加一個系統調用API呢?本文以具體實踐的步驟一步一步來講解增加KVM系統API的方法。
其實為KVM增加一個系統調用API比為Linux增加一個系統調用API還簡單。大致就分成兩步工作就完成。一步是在classes.zip中增加一個你自己新增的class,一步是在KVM的nativeCore.c中實現這個新增的class的nativeapi函數。
下面以org.test.MiniTest這個新增的class為例來實現一個TestInt()系統調用函數。函數的功能很簡單,就是返回一個整數9999。
1.新增org.test.MiniTest類
從SUN那裡下載到j2me_cldc1.1版本的KVM代碼後。在J2ME_cldcapi目錄下,增加orgestMiniTest.Java的包目錄以及Java文件。然後寫上如下的代碼:
- packageorg.test;
- publicclassMiniTest
- {
- publicstaticnativeintTestInt();
- }
2.進行第一次編譯
根據上一篇文章中的KVM編譯方法,在命令提示符下,跳到目錄J2ME_cldcuildwin32下,輸入make命令進行第一次整體編譯。不過,這次編譯過程在編譯連接KVM中的*.o文件的時候,會提示一個找到_Java_org_test_MiniTest_TestInt符號的錯誤提示。
這是因為在我們只是在org.test.MiniTest中定義了這個native函數TestInt,但是並沒有在KVM的任何一個c文件中實現其對應的函數。
首先編譯過程是用javac來編譯J2ME_cldc/api裡面的所有的*.java文件,然後將其class文件打包成一個classes.zip,然後JCC這個工具會默認根據classes.zip生成ROMJavaWin.c和nativeFunctionTableWin.c。而在ROMJavaWin.c聲明這個native函數:
- externvoidJava_org_test_MiniTest_TestInt(void);
3.實現Java_org_test_MiniTest_TestInt函數
從KVM中的代碼可以看到,KVM默認都是把一些native函數放到了nativeCore.c這個文件裡面。你也可以自己去新增一些C程序文件,不過本例就把這個Java_org_test_MiniTest_TestInt放在了nativeCore.c文件。
下面是代碼:
- voidJava_org_test_MiniTest_TestInt(void)
- {
- pushStack(9999);
- }
這裡為什麼把返回值使用pushStack這個宏來返回的原因就不好說了,關於JAVA運行的方式其實就是一個堆棧,Java的字節碼其實就是一種棧式語言,這個在編譯原理裡面的中間代碼生成那一章可以找到它的原型和其說明。再者,還可以看《InsideJavaVirtualMachine》這本書。
4.第二次編譯
第二次編譯就是可以生成真正的kvm.exe文件了。還是跟第一次編譯以及上一篇編譯KVM的方法一樣,敲入make命令即可。
5.測試MiniTest.TestInt這個API
自己寫了一個Test的類,來測試這個API:
- importorg.test.*;
- classTest{
- publicstaticvoidmain(String[]args){
- System.out.println("TestResult="+MiniTest.TestInt());
- }
- }
用Javac編譯的時候,需要把前面的J2ME_cldc/classes.zip拷貝過來,執行:
- javac-classpathclasses.zipTest.Java
- kvm-classpath.Test