目錄
相關文章
Android NDK開發(fā):java調(diào)用dll動態(tài)鏈接庫方法
Android NDK開發(fā):JNIEnv的原理
Android NDK開發(fā):C修改Java的屬性
Android NDK開發(fā):C調(diào)用Java層方法
Android NDK開發(fā):C創(chuàng)建Java層的對象
C創(chuàng)建數(shù)組
SetIntArrayRegion函數(shù)使用
#include "../com_itfitness_NdkDemo.h"
#include <malloc.h>
JNIEXPORT jintArray JNICALL Java_com_itfitness_NdkDemo_createIntArray
(JNIEnv* env, jclass clazz, jint array_size) {
//創(chuàng)建一個大小為array_size的jintArray
jintArray jint_array = (*env)->NewIntArray(env,array_size);
//創(chuàng)建一個大小為array_size的jint類型的數(shù)組
jint *int_array = (jint*)malloc(array_size);
//給jint數(shù)組賦值
int i = 0;
for (i = 0; i < array_size; i ++) {
*(int_array + i) = i;
}
//將jint數(shù)組的值賦給jint_array
//(JNIEnv *env, jintArray array, jsize start, jsize len, const jint *buf);
//env:Java與C的橋梁
//array:被賦值的jintArray
//start:開始賦值的位置(我這是從第0個位置開始)
//len:賦值的長度(我這賦值array_size個數(shù)據(jù))
//buf:數(shù)據(jù)源
(*env)->SetIntArrayRegion(env,jint_array,0,array_size,int_array);
//釋放分配的jint數(shù)組的空間
free(int_array);
//返回jint_array
return jint_array;
}
ReleaseIntArrayElements函數(shù)使用
#include "../com_itfitness_NdkDemo.h"
#include <malloc.h>
JNIEXPORT jintArray JNICALL Java_com_itfitness_NdkDemo_createIntArray
(JNIEnv* env, jclass clazz, jint array_size) {
//創(chuàng)建一個大小為array_size的jintArray
jintArray jint_array = (*env)->NewIntArray(env,array_size);
//創(chuàng)建一個大小為array_size的jint類型的數(shù)組
jint *int_array = (jint*)malloc(array_size);
//給jint數(shù)組賦值
int i = 0;
for (i = 0; i < array_size; i ++) {
*(int_array + i) = i;
}
//將jint數(shù)組的值賦給jint_array
//(JNIEnv *env, jintArray array, jint *elems, jint mode);
//env:Java與C的橋梁
//array:被賦值的jintArray
//elems:數(shù)據(jù)源
//mode:模式
// 0:將內(nèi)容復制回來并釋放原生數(shù)組
// JNI_COMMIT:將內(nèi)容復制回來但是不釋放原生數(shù)組拇泛,一般用于周期性的更新一個Java數(shù)組拓售。
// JNI_ABORT:釋放原生數(shù)組但是不將內(nèi)容復制回來。
(*env)->ReleaseIntArrayElements(env,jint_array,int_array,JNI_COMMIT);
//釋放分配的jint數(shù)組的空間
free(int_array);
//返回jint_array
return jint_array;
}
以上C函數(shù)對應的Java代碼為:
public class NdkDemo {
static {
System.load("E:\\Project\\VS\\NDK操作數(shù)組\\x64\\Release\\NDK操作數(shù)組.dll");
}
public static void main(String[] args) {
int[] intArray = createIntArray(6);
for(int val:intArray){
System.out.print(val + " ");
}
}
/**
* 創(chuàng)建指定大小的int數(shù)組
* @param size
* @return
*/
public static native int[] createIntArray(int size);
}
執(zhí)行結(jié)果為:
C對數(shù)組排序
#include "../com_itfitness_NdkDemo.h"
#include <malloc.h>
/*--------------------冒泡排序---------------------*/
void bubleSort(int data[], int n) {
int i, j, temp;
//兩個for循環(huán),每次取出一個元素跟數(shù)組的其他元素比較
//將最大的元素排到最后窘行。
for (j = 0; j < n - 1; j++) {
//外循環(huán)一次,就排好一個數(shù)图仓,并放在后面罐盔,
//所以比較前面n-j-1個元素即可
for (i = 0; i < n - j - 1; i++) {
if (data[i] > data[i + 1]) {
temp = data[i];
data[i] = data[i + 1];
data[i + 1] = temp;
}
}
}
}
JNIEXPORT void JNICALL Java_com_itfitness_NdkDemo_sortArray
(JNIEnv* env, jclass clazz, jintArray jint_arr) {
//獲取int數(shù)組的元素
jboolean iscopy = JNI_FALSE;//不復制
jint * array_elements = (*env)->GetIntArrayElements(env,jint_arr, iscopy);
//獲取數(shù)組的長度
jsize arr_len = (*env)->GetArrayLength(env,jint_arr);
//冒泡排序
bubleSort(array_elements, arr_len);
//將排序后的數(shù)組賦值給jint_arr并將array_elements釋放
(*env)->ReleaseIntArrayElements(env, jint_arr, array_elements, 0);
}
對應的Java代碼為:
package com.itfitness;
public class NdkDemo {
static {
System.load("E:\\Project\\VS\\NDK操作數(shù)組\\x64\\Release\\NDK操作數(shù)組.dll");
}
public static void main(String[] args) {
int arr[] = {-1, 5, 23, 19, -20};
sortArray(arr);
for (int val : arr) {
System.out.print(val + " ");
}
}
public static native void sortArray(int[] arr);
}
執(zhí)行結(jié)果為: