- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个问题。我正在调用一个测试函数,该函数从 Java 导入函数获取多个字节,然后将该数据作为一个短数组返回。目前我遇到一个问题,即程序因间接引用而崩溃。我的代码是这样的:
#define AR_LEN 8
JNIEXPORT jshortArray JNICALL Java_com_example_datafeed_DataFeed_decode
(JNIEnv *env, jobject obj) {
int out_size = 0;
int i, frame_count;
short *data; /* data stream */
int shutdown = 1;
jbyte *temp;
short data_btes = AR_LEN *2;
jshortArray j_out_data;
// This gets the java class references
jclass cls = (*env)->FindClass(env, "com/example/datafeed/DataFeed");
jmethodID getbytes = (*env)->GetMethodID(env, cls, "getBytes", "(I)[B");
jmethodID outputMethod = (*env)->GetMethodID(env, cls, "playData", "([S)V");
// Set up a return array
j_out_data = (*env)->NewShortArray(env, AR_LEN);
data = malloc(AR_LEN * 2 + 2);
while(shutdown != 0) {
__android_log_print(ANDROID_LOG_ERROR, "Native", "Calling Method %d", data_btes);
// Call the java method to return byte array
jbyteArray getbytes_ret = (*env)->CallObjectMethod(env, obj, getbytes, data_btes);
// check for returned data
__android_log_print(ANDROID_LOG_ERROR, "Native", "Returned %p %d", temp, getbytes_ret);
//Get the array elements. This line seems to crash
temp = (*env)->GetByteArrayElements(env, getbytes_ret, 0);
__android_log_print(ANDROID_LOG_ERROR, "Native", "Array Set");
memcpy(data, temp, data_btes);
__android_log_print(ANDROID_LOG_ERROR, "Native", "Memory Copied");
// Delete the referece to temp
(* env)->DeleteLocalRef(env,temp);
if(temp == NULL) {
shutdown = 0;
} else {
// Set the Array of shorts
(*env)->SetShortArrayRegion(env,j_out_data, 0, AR_LEN, data);
// Call the return method
(*env)->CallObjectMethod(env, obj, outputMethod, j_out_data);
}
}
(* env)->DeleteLocalRef(env,outputMethod);
(* env)->DeleteLocalRef(env,j_out_data);
}
当我运行这段代码时,我得到了这样的输出:
E/Native(18292): Calling Method 16
D/FEED(18292): getting 16 bytes
D/FEED(18292): returning 16 bytes
E/Native(18292): Returned
E/Native(18292): Array Set
E/Native(18292): Memory Copied
W/dalvikvm(18292): JNI WARNING: DeleteLocalRef(0x42e06ac0) failed to find entry
D/OUTPUT(18292): recieved 8 data
E/Native(18292): Calling Method 0x6ded7770 16
E/Native(18292): Returned
W/dalvikvm(18292): Invalid indirect reference 0x8 in decodeIndirectRef
I/dalvikvm(18292): "Thread-55890" prio=5 tid=11 RUNNABLE
I/dalvikvm(18292): | group="main" sCount=0 dsCount=0 obj=0x42e06520 self=0x75221628
I/dalvikvm(18292): | sysTid=18308 nice=0 sched=0/0 cgrp=apps handle=1965187080
I/dalvikvm(18292): | state=R schedstat=( 0 0 0 ) utm=0 stm=0 core=0
I/dalvikvm(18292): at com.example.datafeed.DataFeed.decode(Native Method)
I/dalvikvm(18292): at com.example.datafeed.DataFeed.run(DataFeed.java:68)
I/dalvikvm(18292): at java.lang.Thread.run(Thread.java:841)
E/dalvikvm(18292): VM aborting
A/libc(18292): Fatal signal 11 (SIGSEGV) at 0xdeadd00d (code=1), thread 18308 (Thread-55890)
I/DEBUG(17442): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
I/DEBUG(17442): Build fingerprint: 'samsung/jfltexx/jflte:4.3/JSS15J/I9505XXUEMK9:user/release-keys'
I/DEBUG(17442): Revision: '11'
I/DEBUG(17442): pid: 18292, tid: 18308, name: Thread-55890 >>> com.example.datafeed <<<
I/DEBUG(17442): signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr deadd00d
I/DEBUG(17442): r0 00000000 r1 00000000 r2 00000000 r3 40b76e50
I/DEBUG(17442): r4 deadd00d r5 0000020c r6 752342dc r7 752342e3
I/DEBUG(17442): r8 75336b38 r9 75225fb8 sl 75221638 fp 75336b4c
I/DEBUG(17442): ip 47844001 sp 753368b8 lr 00000001 pc 40afd970 cpsr 60000030
01-17 10:57:55.342: I/DEBUG(17442): d0 0000000000000000 d1 0000000000000000
01-17 10:57:55.342: I/DEBUG(17442): d2 0000000000000000 d3 0000000000000000
01-17 10:57:55.342: I/DEBUG(17442): d4 0010010200000010 d5 000000010000009c
01-17 10:57:55.342: I/DEBUG(17442): d6 ffffffffffffffff d7 3f8000003f800000
01-17 10:57:55.342: I/DEBUG(17442): d8 0000000000000000 d9 0000000000000000
01-17 10:57:55.342: I/DEBUG(17442): d10 0000000000000000 d11 0000000000000000
01-17 10:57:55.342: I/DEBUG(17442): d12 0000000000000000 d13 0000000000000000
01-17 10:57:55.342: I/DEBUG(17442): d14 0000000000000000 d15 0000000000000000
01-17 10:57:55.342: I/DEBUG(17442): d16 6e616c2e6176616a d17 6461657268542e67
01-17 10:57:55.342: I/DEBUG(17442): d18 002e006300650073 d19 00700069006c0063
01-17 10:57:55.342: I/DEBUG(17442): d20 00720061006f0062 d21 00430049002e0064
01-17 10:57:55.342: I/DEBUG(17442): d22 006200700069006c d23 006400720061006f
01-17 10:57:55.342: I/DEBUG(17442): d24 ff00550055005500 d25 ff00550055005500
01-17 10:57:55.342: I/DEBUG(17442): d26 ff00550055005500 d27 ff00550055005500
01-17 10:57:55.342: I/DEBUG(17442): d28 ff00550055005500 d29 ff00550055005500
01-17 10:57:55.342: I/DEBUG(17442): d30 0000000d000d000d d31 0000000d000d000d
01-17 10:57:55.352: I/DEBUG(17442): scr 60000010
01-17 10:57:55.352: I/DEBUG(17442): backtrace:
01-17 10:57:55.352: I/DEBUG(17442): #00 pc 00048970 /system/lib/libdvm.so (dvmAbort+67)
01-17 10:57:55.352: I/DEBUG(17442): #01 pc 0004d41b /system/lib/libdvm.so (dvmDecodeIndirectRef(Thread*, _jobject*)+146)
01-17 10:57:55.352: I/DEBUG(17442): #02 pc 0004e141 /system/lib/libdvm.so
01-17 10:57:55.352: I/DEBUG(17442): #03 pc 00000cf3 /data/app-lib/com.example.datafeed-1/libdatafeed.so (Java_com_example_datafeed_DataFeed_decode+194)
01-17 10:57:55.352: I/DEBUG(17442): #04 pc 0002048c /system/lib/libdvm.so (dvmPlatformInvoke+112)
01-17 10:57:55.352: I/DEBUG(17442): #05 pc 00050ff3 /system/lib/libdvm.so (dvmCallJNIMethod(unsigned int const*, JValue*, Method const*, Thread*)+398)
01-17 10:57:55.352: I/DEBUG(17442): #06 pc 00052ca9 /system/lib/libdvm.so (dvmResolveNativeMethod(unsigned int const*, JValue*, Method const*, Thread*)+256)
01-17 10:57:55.352: I/DEBUG(17442): #07 pc 00029920 /system/lib/libdvm.so
01-17 10:57:55.352: I/DEBUG(17442): #08 pc 0002e2ec /system/lib/libdvm.so (dvmInterpret(Thread*, Method const*, JValue*)+184)
01-17 10:57:55.352: I/DEBUG(17442): #09 pc 00063179 /system/lib/libdvm.so (dvmCallMethodV(Thread*, Method const*, Object*, bool, JValue*, std::__va_list)+292)
01-17 10:57:55.352: I/DEBUG(17442): #10 pc 000631a3 /system/lib/libdvm.so (dvmCallMethod(Thread*, Method const*, Object*, JValue*, ...)+20)
01-17 10:57:55.352: I/DEBUG(17442): #11 pc 00057f03 /system/lib/libdvm.so
01-17 10:57:55.352: I/DEBUG(17442): #12 pc 0000cc60 /system/lib/libc.so (__thread_entry+72)
01-17 10:57:55.352: I/DEBUG(17442): #13 pc 0000cddc /system/lib/libc.so (pthread_create+208)
我注意到 java 方法只被调用一次,尽管 CallObjectMethod 被调用了两次(它打印返回的输出,尽管没有从 java 代码打印调试方法)。不知道如何解决这个问题,我是否必须每次都重置引用?如果有人有任何建议,将不胜感激。
编辑:不确定这是否有帮助,但我已经添加了 java 代码。
public class DataFeed {
static {
System.loadLibrary("datafeed");
}
private BlockingQueue<Byte> inputQueue;
public DataFeed () {
inputQueue=new LinkedBlockingQueue<Byte>();
}
public native void decode();
public byte[] getBytes (int bytes) {
int curbyte = 0;
byte[] retbytes = new byte[bytes];
Log.d("FEED", "getting " + bytes + " bytes");
while(curbyte < bytes) {
try {
retbytes[curbyte] = inputQueue.take();
} catch (InterruptedException e) {
e.printStackTrace();
return null;
}
curbyte ++;
}
Log.d("FEED", "returning " + retbytes.length + " bytes ");
return retbytes;
}
public void playData(short[] outdata) {
Log.d("OUTPUT", "recieved " + outdata.length + " data");
}
}
最佳答案
调用 GetByteArrayElements
时,您应该使用 ReleaseByteArrayElements
而不是 DeleteLocalRef
释放指针。例如:
int fLen = env->GetArrayLength(getbytes_ret);
jbyte *temp = (jbyte *)(*env)->GetByteArrayElements(env, getbytes_ret, NULL);
__android_log_print(ANDROID_LOG_ERROR, "Native", "Array Set");
memcpy(data, temp, fLen );
__android_log_print(ANDROID_LOG_ERROR, "Native", "Memory Copied");
(*env)->ReleaseByteArrayElements(env, getbytes_ret, temp, 0 );
关于java - JNI 报告 Android 中 GetByteArrayElements 的间接引用无效,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21184526/
@After public void afterScenario() { if (ScenarioManager.getScenario().isFailed()) {
我已将 BIRT 报告集成到 Grails 中并设计了一份报告。我的 grails 应用程序中有一个名为 startPeriod (仅限月份和年份)的参数,我想将其传递给 BIRT。然后 BIRT 调
我有一些 Oracle 报告 (.rdf),正在考虑将其转换为 BIRT 报告。有没有办法将 .rdf 文件转换为 BIRT 报告设计文件? 最佳答案 完全自动化的解决方案可能是不可能的。您可以部分自
当 gcc 4.1(使用 gcov)下一行: p = 新类; 报告为 100% 分支覆盖率 为什么? 因为启用了异常处理!!! 为了解决此问题,请指定: -fno-exceptions 在 g++
真的有好 免费 BugZilla 报告工具?我发现 Web 界面上的默认搜索选项太有限了。我最大的问题是缺少 Order By 选项(一次只有 1 个字段,可供选择的字段集非常有限)。我已经做了一些谷
是否可以在 CFMX7 上运行 ColdFusion Report builder 生成的报告? 更明确地说,是否可以将 CF7 中的报告生成引擎更改为 CF8? 最佳答案 我猜这可能很难做到。我记得
根据Lucintel发布的新市场报告,智能家居市场的未来看起来很有吸引力,在家用安全、家电、娱乐、照明、HVAC、医疗保健和厨房应用中将带来许多机遇。 由于COVID-19导致的全球经济衰退,
PHPCodeSniffer 是否生成 HTML 报告? 如果不是呢?怎么办? 目前,我可以运行 PHPCodeSniffer,但它只生成 XML 文件并在终端中显示结果。 如何在 phpunit 中
我在一个包中添加了一个简单的测试。 按照手册中的建议,我尝试让 PHPUnit 加载配置: phpunit -c /app phpunit.xml 看起来像这样:
我有两个从 csv 文件加载的数据框。基本上来自不同的环境但格式/列相似,它们的行/值可能有所不同。我想找到差异并在新的数据框中创建它们。两个数据框也将具有相同的顺序。我有 100 个要比较的文件。提
我想看看是否有办法通过 javadoc 在我的 junit 报告中包含“描述性文本”。 JUnit 4 似乎不像 TestNG 那样支持 @Test 注释的“描述”属性。 到目前为止,我所研究的只有一
我正在使用操作、 Controller 、servlet struts 框架编写 Excel 报告。该报告非常拥挤,已经有大约 10 个单独的查询。由于报告发生变化,我需要再添加大约 10 个查询。有
在放弃 Syleam 的 openerp jasper 模块后,我在 Nan Tic 的 jasper_reports 模块上苦苦挣扎。 它一直给我一个错误: File "C:\Program Fil
我希望创建一个简单的日历。每天由编码器生成条目计数并以日历样式查看。如一月、二月等。或按月显示全年。 database have date_added and encoder columns 我在将它
我必须为报告创建 MySQL 查询。 我有一个表history,它记录产品订单的状态更改。我有订单生命周期(订单流程)的以下状态:新、已确认、正在处理、已发货、已交付、已取消、已退回。订单不一定遵循此
如何将多个查询合并为一个? 例如: //Successful Sales: SELECT username, count(*) as TotalSales, sum(point) as Points
MySQL 优化技术的新手。请找到下面的 mysqltuner.pl 报告,并建议我应该更改 my.cnf 中的哪些变量以优化性能。 还有一个问题- 我无法在我的 my.cnf 中找到一些变量,例如
我想知道,我想将我的 Swing Worker 的某种形式的进度报告回主线程,以便我的界面可以使用随着进度增加而变化的标签进行更新,例如 checking 1/6... checking 2/6...
我正在尝试在“报告”>“销售”下运行 Magento Paypal 结算报告,但每次我尝试运行该报告时,我都会收到消息“由于配置为空,无法获取任何内容” 我查看了“系统”>“配置”>“销售”>“付款方
我想要一个工具来帮助创建 sql 查询(对于非 IT 人员),例如 dbforge。 我希望我们的非 IT 人员(例如运营)创建他们自己的 sql 查询。 我的第二个目标是让他们能够按需执行这些查询。
我是一名优秀的程序员,十分优秀!