草庐IT

JNI_ASSERT

全部标签

c++ - ASSERT 在 CDC SelectObject() 调用上失败 - 我可以尝试什么?

我正在开发多线程win32MFC应用程序。我们正在渲染map并将其显示在用户界面的Pane中,并在顶部显示自定义渲染的对象。呈现速度很慢(~800毫秒),这是在用户界面线程上发生的。我试图将渲染移动到它自己的线程上,以便菜单仍然保持活泼,而另一个渲染仍然可以在后台运行。Draw线程将使用自己的CDC不断渲染。UI线程将调用重绘函数,该函数锁定互斥锁,并获取CBitmap的最后快照并使用UI的CDC绘制它。使用Draw线程的CDC的每个位置都被互斥锁锁定。我看到的是线程通过CreatCompatibleBitmap创建一个新的CBitmap,然后尝试选择新的CBitmap对象到绘制线程的

java - 将 std::unique_ptr 传递给 JNI

我正在用JNI包装一些C++代码,偶然发现了以下工厂函数:std::unique_ptrcreate_metric_planner(*arguments*)我需要将此函数创建的规划器的引用传递回Java以供以后使用,但我很困惑a)如何将其传回,以及b)一旦它被传递下去会发生什么。通常情况下,我都是这样过去的:Director*DIRECTOR=newDirector(arguments);return(jlong)DIRECTOR;它的效果非常好。有人可以解释当使用返回此类指针的工厂函数而不是普通构造函数时使用JNI引用对象的类似过程吗? 最佳答案

c++ - 不满意链接错误 : undefined symbol _ZN5boost6system16generic_categoryEv in java (JNI)

我创建了一个.so文件,其中我根本没有使用boost库(当然早些时候我使用过它),但后来我切换到pthreads并删除了所有头文件和boost.so文件链接生成文件。Java文件编译成功。但是,当我尝试使用java-Djava.library.path=libs/-cpbuild/发送它给我以下错误。线程“main”中的异常java.lang.UnsatisfiedLinkError:/home/aahmed/libplxmsg-java/libs/libplxmsgjavaasyncbinder.so:/home/aahmed/libplxmsg-java/libs/libplxms

c++ - 检查 GTest 中 EXPECT_* 宏的结果或在 ASSERT_* 失败时运行代码

我用GTest编写了C++测试,基本上是这样工作的MyDatadata1=runTest(inputData);MyDatadata2=loadRegressionData();compareMyData(data1,data2);与voidcompareMyData(MyDataconst&data1,MyDataconst&data2){ASSERT_EQ(data1.count,data2.count);//pseudo:foreachelementindata1/data2:EXPECT_EQ(data1.items[i],data2.items[i]);}现在我想将data1

java - JNI : Invoke JAVA method from C++, 返回对象、引用和 GC

当C++程序(!)调用返回对象的java方法时,规则是什么?是否有对该对象的突出引用?我必须调用“DeleteLocalRef”来确保该对象是GCd,还是会自动成为GCd?我不清楚的原因是,在所有示例和官方文档中,声明“DeleteLocalRef”不是必需的,只有当从java调用native“C/C++”方法时,它对我才有意义。但是如果调用线程是调用java的C++方法,JVM怎么知道这个对象可以GCd呢?同理:如果我想缓存对象,我必须调用“NewGlobalRef”吗?找不到对此的任何引用...感谢任何引用和/或澄清 最佳答案

c++ - 由于类型不完整,在 static_assert 中使用 std::is_base_of 失败

我想做的是让一些类继承自extention类。问题是extention类必须知道它正在扩展哪个类。这可以像这样简单地实现:templateclassExtention{public:voidcheck()const{std::cout::value{};classBar:publicExtention{};Foo和Bar类显示了扩展的好坏用法。Foo().check();→Extentionisvalid:trueBar().check();→Extentionisvalid:false我想在编译时检查模板的有效性,这让我写了templateclassExtention{static_

c++ - 是否有任何理由不将 assert() 包装在解析为 gcc 中的 __builtin_unreachable() 的宏中?

上下文:在这个answer,我了解到gcc的__builtin_unreachable()可能会对性能产生一些令人惊讶的影响,因为看起来如下:if(condition)__builtin_unreachable();被完全剥离,用作优化提示,只要condition可以保证没有任何副作用。所以我对此的直接react是我应该创建以下宏,并且绝对在我通常使用assert()的所有地方使用它,因为在assert中会产生副作用()首先会是一个主要错误://TODO:addhandlingofothercompilersasappropriate.#ifdefined(__GNUC__)&&def

java - JNI 从 native 代码调用 JVM 函数/事件?

我想知道native函数是否有可能向Java函数/事件发出信号?基本上我想我会在一个单独的线程上运行一些C++代码并做一些事情,比如处理SIP,然后如果native线程检测到一个传入调用,则能够以某种方式向JVM发出信号。我不确定在JNI中如何进行这样的通信。有什么想法吗? 最佳答案 周围有几篇好文章,例如thisone.这是一个DeveloperWorks文章看起来也不错。 关于java-JNI从native代码调用JVM函数/事件?,我们在StackOverflow上找到一个类似的问

c++ - JNI : How to convert a group of data from c++ to Java

我正在尝试使用JNI将一些数据从C++发送到Java。在C++中我有:Array[0]:stringname="myName"intiterations=16floatvalue=15...etc所以我想使用JNI返回Java上的所有数据,我正在尝试这个,但不起作用JNIEXPORTjobjectArrayJNICALLJava_com_testing_data_MainActivity_getDATA(JNIEnv*env,jobjectobj){//1ºCreateatempobjectjobjectdataClass{jstringname;jintiterations;jflo

c++ - BOOST_STATIC_ASSERT_MSG - 缺少错误信息

我在让BOOST_STATIC_ASSERT_MSG发出有意义的错误消息时遇到问题。我把它归结为:#includenamespaceStaticChecks{BOOST_STATIC_ASSERT_MSG(false,"Whereismyerrormessage?");}指定的错误信息无处可见。相反,我得到以下信息:c:\tryit>x86_64-w64-mingw32-g++-O0-g-m64-Wall-IC:\boost_1_50_0-IC:\MinGW-W64\msys\includecompiletimechecks.cpp-c-ocompiletimechecks.cpp.o