我正在尝试将 jintArray 从 C++ 返回到 Java,但应用程序似乎在 JNI 调用中挂起。我已将问题简化为 jintArray 的创建和填充,尽管我没有收到任何错误。感谢您的帮助。
测试项目以确保一切正常:
include "stdafx.h"
include "windows.h"
include <vector>
include <iostream>
include <jni.h>
using namespace std;
std::vector<jint> childWindows;
BOOL CALLBACK EnumChildProc(HWND hwnd, LPARAM lParam) {
childWindows.push_back((jint) hwnd);
return TRUE;
}
jint* getChildWindows(HWND hWnd) {
childWindows.clear();
::EnumChildWindows(hWnd, EnumChildProc, NULL);
int len = static_cast<int>(childWindows.size());
jint values[100];
std::copy(childWindows.begin(), childWindows.end(), values);
for (std::vector<jint>::const_iterator i = childWindows.begin(); i != childWindows.end(); ++i) {
std::cout << (HWND)*i << ' ';
}
//env->SetIntArrayRegion(childeren, 0, len, values);
return values;
}
int _tmain(int argc, _TCHAR* argv[])
{
getChildWindows((HWND)1377258);
std::cout << " | Windows count: " << childWindows.size() << " ";
return 0;
}
输出:
000D0550 000B04F2 001C047A 0002055E 00020558 00010564 0007054E 00050570 00060512 000C04E0 | Windows count: 10
Java代码:
System.out.println("Get child windows");
System.out.println("Main handle: " + getHandle());
final int[] handles = getChildWindows();
System.out.println("Done getting childs");
Java 输出:
Starting test child windows
Get child windows
Main handle: 525978
JNI代码:
JNIEXPORT jintArray JNICALL Java_main_getChildWindows(JNIEnv *env, jclass c) {
childWindows.clear();
::EnumChildWindows(hWnd, EnumChildProc, NULL);
int len = static_cast<int>(childWindows.size());
jintArray childeren = env->NewIntArray(len);
jint values[100];
std::copy(childWindows.begin(), childWindows.end(), values);
env->SetIntArrayRegion(childeren, (jsize)0, (jsize)len, values);
//env->ReleaseIntArrayElements(childeren, values, 0);
return childeren;
}
最佳答案
您没有在 JNI 调用后检查错误。这可能会导致这样一种情况,即您的代码崩溃不是发生在出错的地方,而是发生在下一个调用 JVM 的地方。当发生这种情况时,您不会得到任何友好意义上的“错误”——您获得这些错误的机会是检查返回值并查询 JVM 以查找未决异常。 (见下文。)
以你的情况为例,如果
jintArray childeren = env->NewIntArray(len)
生成异常(在 JVM 中的 Java 中),您的代码将继续在 native 代码中越过该行,但 JVM 仍将保留该异常。下次您调入 JVM 时,恰好是您确定设置数组值的行,代码将崩溃。您需要明确清除异常。
无论如何,您应该检查返回值并检查异常。 (请参阅 ExceptionOccurred 和 ExceptionClear 的 JNI 文档。)我敢打赌,由于某种原因,您未能获得分配的数组。从你的代码中我不清楚为什么会发生这种情况,但这会给你一个具体的起点,即如果你有异常或者你有一个空引用,它会给你关于出错的信息。它还可能会将您的搜索转移到出现问题的位置。
祝你好运!
关于java - 从 JNI 返回 jintArray,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31976830/
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
所以我开始关注ruby,很多东西看起来不错,但我对隐式return语句很反感。我理解默认情况下让所有内容返回self或nil但不是语句的最后一个值。对我来说,它看起来非常脆弱(尤其是)如果你正在使用一个不打算返回某些东西的方法(尤其是一个改变状态/破坏性方法的函数!),其他人可能最终依赖于一个返回对方法的目的并不重要,并且有很大的改变机会。隐式返回有什么意义?有没有办法让事情变得更简单?总是有返回以防止隐含返回被认为是好的做法吗?我是不是太担心这个了?附言当人们想要从方法中返回特定的东西时,他们是否经常使用隐式返回,这不是让你组中的其他人更容易破坏彼此的代码吗?当然,记录一切并给出
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
为什么以下不同?Time.now.end_of_day==Time.now.end_of_day-0.days#falseTime.now.end_of_day.to_s==Time.now.end_of_day-0.days.to_s#true 最佳答案 因为纳秒数不同:ruby-1.9.2-p180:014>(Time.now.end_of_day-0.days).nsec=>999999000ruby-1.9.2-p180:015>Time.now.end_of_day.nsec=>999999998
在Ruby1.9.3(可能还有更早的版本,不确定)中,我试图弄清楚为什么Ruby的String#split方法会给我某些结果。我得到的结果似乎与我的预期相反。这是一个例子:"abcabc".split("b")#=>["a","ca","c"]"abcabc".split("a")#=>["","bc","bc"]"abcabc".split("c")#=>["ab","ab"]在这里,第一个示例返回的正是我所期望的。但在第二个示例中,我很困惑为什么#split返回零长度字符串作为返回数组的第一个值。这是什么原因呢?这是我所期望的:"abcabc".split("a")#=>["bc"
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/