- Today
- Total
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 재능이의 돈버는 일기
- StresslessLife
- K_JIN2SM
- 소소한 일상
- My Life Style & Memory a Box
- Blog's generation
- 공감 스토리
- 취객의 프로그래밍 연구실
- Love Me
- Dream Archive
- 세상에 발자취를 남기다 by kongmingu
- hanglesoul
- 카마의 IT 초행길
- 느리게.
- 미친듯이 즐겨보자..
- Joo studio
- Gonna be insane
- 악 다 날아갔어!! 갇대밋! 왓더...
- xopowo05
- 맑은공기희망운동
- 엔지니어 독립운동
- 혁준 블로그
- Simple in Complex with Simple
- 무의식이 의식을 지배한다
드럼치는 프로그래머
[JNI/NDK] JNI에서 기본형 배열을 다루는 예 본문
HelloJNI.java
public class HelloJNI {
static{
System.loadLibrary("my_dll");
}
/* byte[]을 전달하고 byte[]을 리턴하는 예 */
public native byte[] byteArrayTest(byte [] name);
public static void main(String[] args) throws Exception{
HelloJNI test = new HelloJNI();
byte[] src = {0,1,2,3,4,5,6,7,8,9};
byte[] result = test.byteArrayTest(src);
System.out.println("Java측에서 수신한 배열[9]:"+result[9]);
}
}
HelloJNI.h
/* DO NOT EDIT THIS FILE - it is machine generated */
#include <jni.h>
/* Header for class HelloJNI */
#ifndef _Included_HelloJNI
#define _Included_HelloJNI
#ifdef __cplusplus
extern "C" {
#endif
/*
* Class: HelloJNI
* Method: byteArrayTest
* Signature: ([B)[B
*/
JNIEXPORT jbyteArray JNICALL Java_HelloJNI_byteArrayTest
(JNIEnv *, jobject, jbyteArray);
#ifdef __cplusplus
}
#endif
#endif
my_dll.c
#include "HelloJNI.h"
#include <stdio.h>
JNIEXPORT jbyteArray JNICALL Java_HelloJNI_byteArrayTest
(JNIEnv *env, jobject jobj, jbyteArray jsrc) {
jbyteArray result;
jsize n = (*env)->GetArrayLength(env, jsrc);
jbyte *pbyte = (*env)->GetByteArrayElements(env,jsrc, 0);
int i = 0;
jbyte value;
result = (*env)->NewByteArray(env, 10);
for(i=0;i<n;i++) {
(*env)->GetByteArrayRegion(env, jsrc,i,1,&value);
printf("%d-->%d \n", i, value);
(*env)->SetByteArrayRegion(env, result, i, 1, &value);
}
/*혹은 다음과 같이 한꺼번에 배열원소를 초기화할 수 있다 */
(*env)->SetByteArrayRegion(env, result, 0, 10, pbyte);
(*env)->ReleaseByteArrayElements(env, jsrc, pbyte, 0);
return result;
}
Release<Type>ArrayElements()메소드의 3번째 아규먼트에 대하여
0 : 원본배열에 변경내용을 반영하고 메모리 회수가 요구되면 메모리를 회수한다
JNI_COMMIT : 원본배열에 변경내용을 반영하나, 메모리는 회수하지 않는다(배열의 원본으로 작업한 경우 유용함)
JNI_ABORT : 원본배열에 변경내용을 반영하지 않고, 메모리는 회수한다(복사본으로 작업하고 배열수정이 없는 경우 유용)
'★─Programing > ☆─JNI | NDK' 카테고리의 다른 글
[JNI/NDK] JNI(Java Native Interface) 프로그래밍 방법 (0) | 2013.05.06 |
---|---|
[JNI/NDK] Java 메소드 시그니쳐 확인 (JNI Signature) (0) | 2013.04.22 |
[JNI/NDK] JNI에서 한글처리 문제와 그 해결방법 (0) | 2013.04.22 |
[JNI/NDK] Java의 String 을 JNI에서 다루는 예 (0) | 2013.04.22 |
[JNI/NDK] 자바의 int 형과 같은 기본형 데이터 타입을 JNI에서 다루는 예 (0) | 2013.04.22 |