導航:首頁 > 編程語言 > javanative用法

javanative用法

發布時間:2021-03-03 23:48:58

A. java中的native關鍵字有什麼作用

以下分三點來講述一下java native:

1、什麼是Native Method
簡單地講,一個Native Method就是一個java調用非java代碼的介面。一個Native Method是這樣一個java的方法:該方法的實現由非java語言實現,比如C。這個特徵並非java所特有,很多其它的編程語言都有這一機制,比如在C++中,你可以用extern "C"告知C++編譯器去調用一個C的函數。
"A native method is a Java method whose implementation is provided by non-java code."
在定義一個native method時,並不提供實現體(有些像定義一個java interface),因為其實現體是由非java語言在外面實現的。,下面給了一個示例:
public class IHaveNatives
{
native public void Native1( int x ) ;
native static public long Native2() ;
native synchronized private float Native3( Object o ) ;
native void Native4( int[] ary ) throws Exception ;
}
這些方法的聲明描述了一些非java代碼在這些java代碼里看起來像什麼樣子(view).
標識符native可以與所有其它的java標識符連用,但是abstract除外。這是合理的,因為native暗示這些方法是有實現體的,只不過這些實現體是非java的,但是abstract卻顯然的指明這些方法無實現體。native與其它java標識符連用時,其意義同非Native Method並無差別,比如native static表明這個方法可以在不產生類的實例時直接調用,這非常方便,比如當你想用一個native method去調用一個C的類庫時。上面的第三個方法用到了native synchronized,JVM在進入這個方法的實現體之前會執行同步鎖機制(就像java的多線程。)
一個native method方法可以返回任何java類型,包括非基本類型,而且同樣可以進行異常控制。這些方法的實現體可以制一個異常並且將其拋出,這一點與java的方法非常相似。當一個native method接收到一些非基本類型時如Object或一個整型數組時,這個方法可以訪問這非些基本型的內部,但是這將使這個native方法依賴於你所訪問的java類的實現。有一點要牢牢記住:我們可以在一個native method的本地實現中訪問所有的java特性,但是這要依賴於你所訪問的java特性的實現,而且這樣做遠遠不如在java語言中使用那些特性方便和容易。
native method的存在並不會對其他類調用這些本地方法產生任何影響,實際上調用這些方法的其他類甚至不知道它所調用的是一個本地方法。JVM將控制調用本地方法的所有細節。需要注意當我們將一個本地方法聲明為final的情況。用java實現的方法體在被編譯時可能會因為內聯而產生效率上的提升。但是一個native final方法是否也能獲得這樣的好處卻是值得懷疑的,但是這只是一個代碼優化方面的問題,對功能實現沒有影響。
如果一個含有本地方法的類被繼承,子類會繼承這個本地方法並且可以用java語言重寫這個方法(這個似乎看起來有些奇怪),同樣的如果一個本地方法被fianl標識,它被繼承後不能被重寫。
本地方法非常有用,因為它有效地擴充了jvm.事實上,我們所寫的java代碼已經用到了本地方法,在sun的java的並發(多線程)的機制實現中,許多與操作系統的接觸點都用到了本地方法,這使得java程序能夠超越java運行時的界限。有了本地方法,java程序可以做任何應用層次的任務。

2、為什麼要使用Native Method
java使用起來非常方便,然而有些層次的任務用java實現起來不容易,或者我們對程序的效率很在意時,問題就來了。
與java環境外交互:
有時java應用需要與java外面的環境交互。這是本地方法存在的主要原因,你可以想想java需要與一些底層系統如操作系統或某些硬體交換信息時的情況。本地方法正是這樣一種交流機制:它為我們提供了一個非常簡潔的介面,而且我們無需去了解java應用之外的繁瑣的細節。
與操作系統交互:
JVM支持著java語言本身和運行時庫,它是java程序賴以生存的平台,它由一個解釋器(解釋位元組碼)和一些連接到本地代碼的庫組成。然而不管怎 樣,它畢竟不是一個完整的系統,它經常依賴於一些底層(underneath在下面的)系統的支持。這些底層系統常常是強大的操作系統。通過使用本地方法,我們得以用java實現了jre的與底層系統的交互,甚至JVM的一些部分就是用C寫的,還有,如果我們要使用一些java語言本身沒有提供封裝的操作系統的特性時,我們也需要使用本地方法。
Sun's Java
Sun的解釋器是用C實現的,這使得它能像一些普通的C一樣與外部交互。jre大部分是用java實現的,它也通過一些本地方法與外界交互。例如:類java.lang.Thread 的 setPriority()方法是用java實現的,但是它實現調用的是該類里的本地方法setPriority0()。這個本地方法是用C實現的,並被植入JVM內部,在Windows 95的平台上,這個本地方法最終將調用Win32 SetPriority() API。這是一個本地方法的具體實現由JVM直接提供,更多的情況是本地方法由外部的動態鏈接庫(external dynamic link library)提供,然後被JVM調用。

3、JVM怎樣使Native Method跑起來:
我們知道,當一個類第一次被使用到時,這個類的位元組碼會被載入到內存,並且只會回載一次。在這個被載入的位元組碼的入口維持著一個該類所有方法描述符的list,這些方法描述符包含這樣一些信息:方法代碼存於何處,它有哪些參數,方法的描述符(public之類)等等。
如果一個方法描述符內有native,這個描述符塊將有一個指向該方法的實現的指針。這些實現在一些DLL文件內,但是它們會被操作系統載入到java程序的地址空間。當一個帶有本地方法的類被載入時,其相關的DLL並未被載入,因此指向方法實現的指針並不會被設置。當本地方法被調用之前,這些DLL才會被載入,這是通過調用java.system.loadLibrary()實現的。

最後需要提示的是,使用本地方法是有開銷的,它喪失了java的很多好處。如果別無選擇,我們可以選擇使用本地方法。

B. JAVA怎麼調用 native方法不要在mian里調用就可以了

JAVA比較典型的native的使用方式,用loadLibrary導入存在源文件目錄下的*.dll文件,然後定義native方法時版,與c/c++實現的函數有相同權的參數和返回類型。

{

static{

System.loadLibrary("OpticalFlow");

}();

publicnativestaticint[]getGoodFeatureListForTrack();

publicnativestaticint[]getMatchedFeatureList();

();

publicnativestaticvoiddispose();

}

C. java什麼情況下用native方法

Java不是完美的,Java的不足除了體現在運行速度上要比傳統的C++慢許多之外,Java無法直接訪問內到操作系統底層(如容系統硬體等),為此Java使用native方法來擴展Java程序的功能。
可以將native方法比作Java程序同C程序的介面,其實現步驟:
1、在Java中聲明native()方法,然後編譯。
2、用javah產生一個.h文件。
3、寫一個.cpp文件實現native導出方法,其中需要包含第二步產生的.h文件(注意其中又包含了JDK帶的jni.h文件)。
4、將第三步的.cpp文件編譯成動態鏈接庫文件。
5、在Java中用System.loadLibrary()方法載入第四步產生的動態鏈接庫文件,這個native()方法就可以在Java中被訪問了。

JAVA的native方法適用的情況:
1、為了使用底層的主機平台的某個特性,而這個特性不能通過JAVA API訪問。
2、為了訪問一個老的系統或者使用一個已有的庫,而這個系統或這個庫不是用JAVA編寫的。
3、為了加快程序的性能,而將一段時間敏感的代碼作為本地方法實現。

D. java中native的用法

其實就是JNI。native是方法修飾符。Native方法是由另外一種語言(如c/C++,FORTRAN,匯編)實現的本地方法。因為在外部實現了方法,所以在java代碼中,就不需要聲明了。

E. 在java中native是一個什麼修飾啊

java本地方法,就是java調用c語言,c++語言。delphi語言的時候會用到

一般應該極力避免這么做!

F. JAVA中的native是什麼許可權啊

Java不是完美的,Java的不足除了體現在運行速度上要比傳統的C++慢許多之外,Java無法直接訪問到操作系統底層(如系統硬體等),為此Java使用native方法來擴展Java程序的功能。

可以將native方法比作Java程序同C程序的介面,其實現步驟:

1、在Java中聲明native()方法,然後編譯;

2、用javah產生一個.h文件;

3、寫一個.cpp文件實現native導出方法,其中需要包含第二步產生的.h文件(注意其中又包含了JDK帶的jni.h文件);

4、將第三步的.cpp文件編譯成動態鏈接庫文件;

5、在Java中用System.loadLibrary()方法載入第四步產生的動態鏈接庫文件,這個native()方法就可以在Java中被訪問了。

JAVA本地方法適用的情況

1.為了使用底層的主機平台的某個特性,而這個特性不能通過JAVA API訪問

2.為了訪問一個老的系統或者使用一個已有的庫,而這個系統或這個庫不是用JAVA編寫的

3.為了加快程序的性能,而將一段時間敏感的代碼作為本地方法實現。

首先寫好JAVA文件

/*

* Created on 2005-12-19 Author shaoqi

*/

package com.hode.hodeframework.modelupdate;

public class CheckFile

{

public native void displayHelloWorld();

static

{

System.loadLibrary("test");

}

public static void main(String[] args) {

new CheckFile().displayHelloWorld();

}

}

然後根據寫好的文件編譯成CLASS文件

然後在classes或bin之類的class根目錄下執行javah -jni com.hode.hodeframework.modelupdate.CheckFile,

就會在根目錄下得到一個com_hode_hodeframework_modelupdate_CheckFile.h的文件

然後根據頭文件的內容編寫com_hode_hodeframework_modelupdate_CheckFile.c文件

#include "CheckFile.h"

#include

#include

JNIEXPORT void JNICALL Java_com_hode_hodeframework_modelupdate_CheckFile_displayHelloWorld(JNIEnv *env, jobject obj)

{

printf("Hello world!\n");

return;

}

之後編譯生成DLL文件如「test.dll」,名稱與System.loadLibrary("test")中的名稱一致

vc的編譯方法:cl -I%java_home%\include -I%java_home%\include\win32 -LD com_hode_hodeframework_modelupdate_CheckFile.c -Fetest.dll

最後在運行時加參數-Djava.library.path=[dll存放的路徑]

G. native在java中的定義

JNI是Java Native Interface的 縮寫。從Java 1.1開始,Java Native Interface (JNI)標准成為java平台的一部分,它允許Java代碼和其他語言寫的代碼進行交互。JNI一開始是為了本地已編譯語言,尤其是C和C++而設計 的,但是它並不妨礙你使用其他語言,只要調用約定受支持就可以了。
使用java與本地已編譯的代碼交互,通常會喪失平台可移植性。但是,有些情況下這樣做是可以接受的,甚至是必須的,比如,使用一些舊的庫,與硬體、操作系統進行交互,或者為了提高程序的性能。JNI標准至少保證本地代碼能工作在任何Java 虛擬機實現下。
JNI(Java Native Interface)的書寫步驟
·編寫帶有native聲明的方法的java類
·使用javac命令編譯所編寫的java類
·使用javah ?jni java類名生成擴展名為h的頭文件
·使用C/C++(或者其他編程想語言)實現本地方法
·將C/C++編寫的文件生成動態連接庫

1) 編寫java程序:
這里以HelloWorld為例。
代碼1:
class HelloWorld {
public native void displayHelloWorld();
static {
System.loadLibrary("hello");
}
public static void main(String[] args) {
new HelloWorld().displayHelloWorld();
}
}
聲明native方法:如果你想將一個方法做為一個本地方法的話,那麼你就必須聲明改方法為native的,並且不能實現。其中方法的參數和返回值在後面講述。
Load 動態庫:System.loadLibrary("hello");載入動態庫(我們可以這樣理解:我們的方法displayHelloWorld()沒 有實現,但是我們在下面就直接使用了,所以必須在使用之前對它進行初始化)這里一般是以static塊進行載入的。同時需要注意的是 System.loadLibrary();的參數「hello」是動態庫的名字。
main()方法
2) 編譯沒有什麼好說的了
javac HelloWorld.java
3) 生成擴展名為h的頭文件
javah ?jni HelloWorld
頭文件的內容:
/* DO NOT EDIT THIS FILE - it is machine generated */
#include
/* Header for class HelloWorld */
#ifndef _Included_HelloWorld
#define _Included_HelloWorld
#ifdef __cplusplus
extern "C" {
#endif
/*
* Class: HelloWorld
* Method: displayHelloWorld
* Signature: ()V
*/
JNIEXPORT void JNICALL Java_HelloWorld_displayHelloWorld
(JNIEnv *, jobject);
#ifdef __cplusplus
}
#endif
#endif
(這 里我們可以這樣理解:這個h文件相當於我們在java裡面的介面,這里聲明了一個Java_HelloWorld_displayHelloWorld (JNIEnv *, jobject);方法,然後在我們的本地方法裡面實現這個方法,也就是說我們在編寫C/C++程序的時候所使用的方法名必須和這里的一致)。
4) 編寫本地方法
實現和由javah命令生成的頭文件裡面聲明的方法名相同的方法。
代碼2:
1 #include
2 #include "HelloWorld.h"
3 #include
4 JNIEXPORT void JNICALL Java_HelloWorld_displayHelloWorld(JNIEnv *env, jobject obj)
{
printf("Hello world!\n");
return;
}
注 意代碼2中的第1行,需要將jni.h(該文件可以在%JAVA_HOME%/include文件夾下面找到)文件引入,因為在程序中的JNIEnv、 jobject等類型都是在該頭文件中定義的;另外在第2行需要將HelloWorld.h頭文件引入(我是這么理解的:相當於我們在編寫java程序的 時候,實現一個介面的話需要聲明才可以,這里就是將HelloWorld.h頭文件裡面聲明的方法加以實現。當然不一定是這樣)。然後保存為 HelloWorldImpl.c就 ok了。
5) 生成動態庫
這里以在Windows中為例,需要生成dll文件。在保存HelloWorldImpl.c文件夾下面,使用VC的編譯器cl成。
cl -I%java_home%\include -I%java_home%\include\win32 -LD HelloWorldImp.c -Fehello.dll
注 意:生成的dll文件名在選項-Fe後面配置,這里是hello,因為在HelloWorld.java文件中我們loadLibary的時候使用的名字 是hello。當然這里修改之後那裡也需要修改。另外需要將-I%java_home%\include -I%java_home%\include\win32參數加上,因為在第四步裡面編寫本地方法的時候引入了jni.h文件。
6) 運行程序
java HelloWorld就ok。
JNI(Java Native Interface)調用中考慮的問題
在首次使用JNI的時候有些疑問,後來在使用中一一解決,下面就是這些問題的備忘:
1。 java和c是如何互通的?
其實不能互通的原因主要是數據類型的問題,jni解決了這個問題,例如那個c文件中的jstring數據類型就是java傳入的String對象,經過jni函數的轉化就能成為c的char*。
對應數據類型關系如下表:
Java 類型 本地c類型 說明
boolean jboolean 無符號,8 位
byte jbyte 無符號,8 位
char jchar 無符號,16 位
short jshort 有符號,16 位
int jint 有符號,32 位
long jlong 有符號,64 位
float jfloat 32 位
double jdouble 64 位
void void N/A
2. 如何將java傳入的String參數轉換為c的char*,然後使用?
java 傳入的String參數,在c文件中被jni轉換為jstring的數據類型,在c文件中聲明char* test,然後test = (char*)(*env)->GetStringUTFChars(env, jstring, NULL);注意:test使用完後,通知虛擬機平台相關代碼無需再訪問:(*env)->ReleaseStringUTFChars(env, jstring, test);
3. 將c中獲取的一個char*的buffer傳遞給java?
這個char*如果是一般的字元串的話,作為string傳回去就可以了。如果是含有』\0』的buffer,最好作為bytearray傳出,因為可以制定的length,如果到string,可能到』\0』就截斷了。
有兩種方式傳遞得到的數據:
一種是在jni中直接new一個byte數組,然後調用函數(*env)->SetByteArrayRegion(env, bytearray, 0, len, buffer);將buffer的值到bytearray中,函數直接return bytearray就可以了。
一種是return錯誤號,數據作為參數傳出,但是java的基本數據類型是傳值,對象是傳遞的引用,所以將這個需要傳出的byte數組用某個類包一下,如下:
class RetObj
{
public byte[] bytearray;
}
這個對象作為函數的參數retobj傳出,通過如下函數將retobj中的byte數組賦值便於傳出。代碼如下:
jclass cls;
jfieldID fid;
jbyteArray bytearray;
bytearray = (*env)->NewByteArray(env,len);
(*env)->SetByteArrayRegion(env, bytearray, 0, len, buffer);
cls = (*env)->GetObjectClass(env, retobj);
fid = (*env)->GetFieldID(env, cls, "retbytes", "[B"]);
(*env)->SetObjectField(env, retobj, fid, bytearray);
4. 不知道佔用多少空間的buffer,如何傳遞出去呢?
在jni的c文件中new出空間,傳遞出去。java的數據不初始化,指向傳遞出去的空間即可。

H. 怎樣理解java native方法

什麼是Native Method
簡單地講,一個Native Method就是一個java調用非java代碼的介面。一個Native Method是這樣一個java的方法:該方法的實現由非語言實現,比如C。這個特徵並非java所特有,很多其它的編程語言都有這一機制,比如在C++中,你可以用extern "C"告知C++編譯器去調用一個C的函數。
"A native method is a Java method whose implementation is provided by non-java code."
在定義一個native method時,並不提供實現體(有些像定義一個java interface),因為其實現體是由非java語言在外面實現的。,下面給了一個示例:
public class IHaveNatives
{
native public void Native1( int x ) ;
native static public long Native2() ;
native synchronized private float Native3( Object o ) ;
native void Native4( int[] ary ) throws Exception ;
}
這些方法的聲明描述了一些非java代碼在這些java代碼里看起來像什麼樣子(view).
標識符native可以與所有其它的java標識符連用,但是abstract除外。這是合理的,因為native暗示這些方法是有實現體的,只不過這些實現體是非java的,但是abstract卻顯然的指明這些方法無實現體。native與其它java標識符連用時,其意義同非Native Method並無差別,比如native static表明這個方法可以在不產生類的實例時直接調用,這非常方便,比如當你想用一個native method去調用一個C的類庫時。上面的第三個方法用到了native synchronized,JVM在進入這個方法的實現體之前會執行同步鎖機制(就像java的多線程。)
一個native method方法可以返回任何java類型,包括非基本類型,而且同樣可以進行異常控制。這些方法的實現體可以制一個異常並且將其拋出,這一點與java的方法非常相似。當一個native method接收到一些非基本類型時如Object或一個整型數組時,這個方法可以訪問這非些基本型的內部,但是這將使這個native方法依賴於你所訪問的java類的實現。有一點要牢牢記住:我們可以在一個native method的本地實現中訪問所有的java特性,但是這要依賴於你所訪問的java特性的實現,而且這樣做遠遠不如在java語言中使用那些特性方便和容易。
native method的存在並不會對其他類調用這些本地方法產生任何影響,實際上調用這些方法的其他類甚至不知道它所調用的是一個本地方法。JVM將控制調用本地方法的所有細節。需要注意當我們將一個本地方法聲明為final的情況。用java實現的方法體在被編譯時可能會因為內聯而產生效率上的提升。但是一個native final方法是否也能獲得這樣的好處卻是值得懷疑的,但是這只是一個代碼優化方面的問題,對功能實現沒有影響。
如果一個含有本地方法的類被繼承,子類會繼承這個本地方法並且可以用java語言重寫這個方法(這個似乎看起來有些奇怪),同樣的如果一個本地方法被fianl標識,它被繼承後不能被重寫。
本地方法非常有用,因為它有效地擴充了jvm.事實上,我們所寫的java代碼已經用到了本地方法,在sun的java的並發(多線程)的機制實現中,許多與操作系統的接觸點都用到了本地方法,這使得java程序能夠超越java運行時的界限。有了本地方法,java程序可以做任何應用層次的任務。

I. native 關鍵字在java中怎麼用

native關鍵字用法
native是與C++聯合開發的時候用的!java自己開發不用的!
使用native關鍵字說明這個方法是原生函數,也就是這個方法是用C/C++語言實現的,並且被編譯成了DLL,由java去調用。 這些函數的實現體在DLL中,JDK的源代碼中並不包含,你應該是看不到的。對於不同的平台它們也是不同的。這也是java的底層機制,實際上java就是在不同的平台上調用不同的native方法實現對操作系統的訪問的。1。native 是用做java 和其他語言(如c++)進行協作時用的 也就是native 後的函數的實現不是用java寫的 2。既然都不是java,那就別管它的源代碼了,呵呵native的意思就是通知操作系統, 這個函數你必須給我實現,因為我要使用。 所以native關鍵字的函數都是操作系統實現的, java只能調用。java是跨平台的語言,既然是跨了平台,所付出的代價就是犧牲一些對底層的控制,而java要實現對底層的控制,就需要一些其他語言的幫助,這個就是native的作用了

J. Java 中native方法的應用

其實就是JNI。
native是方法修飾符。Native方法是由另外一種語言(如c/c++,FORTRAN,匯編)實現的本內地方法。因為在容外部實現了方法,所以在java代碼中,就不需要聲明了,有點類似於借口方法。Native可以和其他一些修飾符連用,但是abstract方法和Interface方法不能用native來修飾。

閱讀全文

與javanative用法相關的資料

熱點內容
韓國電影健身房教練 瀏覽:942
金剛2免費完整版正片 瀏覽:477
女蛇妖的電影 瀏覽:640
蘋果手機清除文件垃圾的方法 瀏覽:689
騰訊視頻有哪些版本 瀏覽:405
用數據線微信文件怎麼轉電腦 瀏覽:262
黑人教室的英語作弊教師 瀏覽:651
oracleexp指定版本 瀏覽:150
李銀美韓國 瀏覽:319
u12linux 瀏覽:783
限制級視頻網 瀏覽:636
.ybci.waq ?x 瀏覽:765
騰訊文件蘋果板 瀏覽:173
外國女同電影 瀏覽:336
為什麼同一文件壓縮比原文大 瀏覽:206
北京哪裡有數控機床編程 瀏覽:135
男兒當自強版本 瀏覽:164
恐怖網站電影在線 瀏覽:207
webbrowser密碼框 瀏覽:720
大奶按摩電影 瀏覽:126

友情鏈接