(原)JNI中env->GetByteArrayElements和AndroidBitmap_getInfo的冲突

也不是很确定,前段时间的代码没有出问题,但是今天调试了半天,一直崩溃:vm aborting。

以前的部分代码:

 1 JNIEXPORT void JNICALL XXX
 2   (JNIEnv* env,jobject thiz, jobject bitmap, jbyteArray databuf, jint width, jint height)
 3 {
 4     jboolean* pArraydata = (jboolean*)env->GetPrimitiveArrayCritical(databuf, 0);
 5     AndroidBitmapInfo  info;
 6     int                ret;
 7     if ((ret = AndroidBitmap_getInfo(env, bitmap, &info)) < 0)
 8     {
 9        XXX;
10     }
11     if (info.format != ANDROID_BITMAP_FORMAT_RGBA_8888)
12     {
13       XXX;
14     }
15     if ((ret = AndroidBitmap_lockPixels(env, bitmap, &pixels)) < 0)
16     {
17        XXX;
18     }
19     AndroidBitmap_unlockPixels(env, bitmap);
20     env->ReleasePrimitiveArrayCritical(databuf, pArraydata, 0);
21 }    

后来发现不用bitmap的这些代码程序没错,或者注释掉GetPrimitiveArrayCritical的相关代码程序也没错。但是两者同时出现的话,程序就崩溃。

之后想到不使用GetPrimitiveArrayCritical,换成别的代码试一下。

1     unsigned char isCopy;
2     jbyte* pArrayimgdata = env->GetByteArrayElements(databuf,&isCopy); % 此处是否使用isCopy都没关系,只要和最后release对应上就行。3   if ((ret = AndroidBitmap_getInfo(env, bitmaps, &info)) < 0) 4    {
5       XXX;
6     }
7     XXX;
8     env->ReleaseByteArrayElements(databuf,pArrayimgdata,isCopy);

程序就不会崩溃了。

ps:仍旧没有弄懂为什么以前的代码可以用,今天就不能用了(当然,以前的代码中还有别的代码,今天的只使用了该部分代码)。

时间: 2024-11-07 09:22:43

(原)JNI中env->GetByteArrayElements和AndroidBitmap_getInfo的冲突的相关文章

jni中调用java方法获取当前apk的签名文件md5值

相应的java方法: void getsign(Context context) throws Exception { PackageInfo localPackageInfo = context.getPackageManager() .getPackageInfo(context.getPackageName(), 64); StringBuilder localStringBuilder = new StringBuilder(); Signature[] arrayOfSignature

Jni中C++和Java的参数传递

Jni中C++和Java的参数传递 如何使用JNI的一些基本方法和过程在网上多如牛毛,如果你对Jni不甚了解,不知道Jni是做什么的,如何建立一个基本的jni程序,或许可以参考下面下面这些文章:利用VC++6.0实现JNI的最简单的例子 JNI入门教程之HelloWorld篇SUN JNI Tutorial谢谢大家的回复,有人说类型不对,己修正.类型请参照: http://docs.oracle.com/javase/7/docs/technotes/guides/jni/spec/types.

jni中的参数含义

#include <jni.h> JNIEXPORT jstring JNICALL Java_com_example_hellojni_MainActivity_helloFromC (JNIEnv * env, jobject obj){ return (*env)->NewStringUTF(env,"hello from C"); }; 参数(JNIEnv * env, jobject obj)中env是JNI函数库,obj是java中调用该方法的那个对象.

[Android Pro] Android studio jni中调用Log输出调试信息

reference to : http://www.linuxidc.com/Linux/2014-02/96341.htm Android 开发中,java 可以方便的使用调试信息Log.i, Log.d ...,Jni层可否使用呢?答案是肯定的. 1 为方便使用,先进行宏定义: eben_hpc_log.h内容如下: #ifndef _Included_hpc_Log#define _Included_hpc_Log#ifdef __cplusplusextern "C" {#en

Base64编解码Android和ios的例子,补充JNI中的例子

1.在Android中java层提供了工具类:android.util.Base64; 里面都是静态方法,方便直接使用: 使用方法如下: Java代码   // Base64 编码: byte [] encode = Base64.encode("Hello, World".getBytes(), Base64.DEFAULT); String enc = new String(encode); Log.d("","base 64 encode = &qu

JNI中C调用Java方法

背景需求 我们需要在JNI的C代码调用Java代码.实现原理:使用JNI提供的反射借口来反射得到Java方法,进行调用. JNI关键方法讲解. 1. 在同一个类中,调用其他方法 JNIEXPORT void JNICALL Java_cn_itcast_ndkcallback_DataProvider_callmethod1 (JNIEnv * env, jobject obj){ //在c代码里面调用java代码里面的方法 // java 反射 //1 . 找到java代码的 class文件

android学习笔记----JNI中的c控制java

面向对象的底层实现 java作为面向对象高级语言,可对现实世界进行建模.和面向过程不同的是面向对象软件的编写不是流程的堆积,而是对业务逻辑的多视角分解和分类.其过程大致为:      1).将知识分解成不同粒度的小概念.      2).对概念进行分类,形成类.模块.系统      3).用计算机语言将其实现为对象(包含操作和数据) 然而,大多程序员编写代码时很少思考面向对象的体系是如何实现的.因为它属于底层,并不必要.但是,学习过Java反射技术并有所思考的人会意识到,面向对象的种种语法本身也

JNI中java类型的简写

  在JNI中,当我们使用GetFieldID/GetStaticFieldID或GetMethodID/GetStaticMethodID及定义JNINativeMethod等时,我们需要表示成员变量的类型,或函数传入参数或返回的类型.JNI把Field的类型,或函数传入参数或返回值的类型进行简写以char*的形式进行表示.      对于成员变量,直接用java类型的简写表示成员变量的类型就可以      比如:"I"表示该成员变量是Int类型                 &q

NS前缀\OC中的注释\访问OC原文件、C原文件中的函数

///////////////////////////////////////// //////////////////////////////////////// NS前缀 NS来自于NeXTStep的一个软件 NeXT Software OC中不支持命名空间(namespace) NS是为了避免命名冲突而给的前缀 看到NS前缀就知道是Cocoa中的系统类的名称 "@"的使用方法 1.@""这个符号表示将C中的字符串转化为OC中的字符串对象 2.@符号 OC中的大

java实现原数组根据下标分隔成两个子数组并且在原数组中交换两个子数组的位置

此类实现:输出一行数组数据,根据输入的下标,以下标位置为结束,将原数组分割成两组子数组.并交换两个子数组的位置,保持子数组中的元素序号不变.如:原数组为7,9,8,5,3,2 以下标3为分割点,分割为子数组一:7,9,8,5.和子数组二:3,2.经过交换算法后的结果应为:3,2,7,9,8,5 有两种交换算法<1>前插法:将子数组3,2另存在一个临时数组中,将原数组7,9,8,5,3,2每一位向后移两个位置  再将子数组3,2插入到移动好元素位置的原数组中.<2>逆置法:将原数组7