草庐IT

JNI_ASSERT

全部标签

java - JNI : How to handle the creation/removal of wrapped C++ object

我想包装一个C++对象,以便我可以从Java访问它。通过阅读jniandusingc++new'edobjectsinjava,我了解了如何在我的Java包装器类中保存对我的C++对象的引用。.不过,我还没有弄清楚的一件事是如何处理我的C++对象的创建和删除。当然,我可以引入创建和删除我的C++对象的native方法,但这意味着我必须在Java中自己处理内存管理……不是很Javaish。在我的Java包装器对象创建和垃圾收集时,是否有任何我应该实现的本地方法被调用? 最佳答案 您必须编写native方法来创建和销毁您的C++对象。关

java - 如何定义泛型类的 JNI 方法签名?

我有一个用java定义的基类。我想像这样调用本地方法:publicclassBase{publicvoiddoSomething(){nativeDoSomething();}privatenativevoidnativeDoSomething();}我的问题是,如何指定泛型类的jni方法签名? 最佳答案 我来晚了,但我会添加它以供将来引用。Java中的泛型是使用TypeErasure实现的,基本上是:泛型只存在于编译时:它们在那之后就消失了,不存在于运行时。这意味着,即使您可以拥有类似publicnativevoidblah(Eg

java - 通过 jni 将每个引用的参数从 C++ 传递到 Java

我正在尝试通过JNI将每个引用的变量从C++传递到Java。一开始,我尝试了一些简单的代码:Javapublicstaticvoidinc(intval){System.out.println("inccalled:"+val);val++;}publicstaticvoiddec(intval){System.out.println("deccalled:"+val);val--;这应该简单地增加/减少使用Java方法在C++代码中创建的变量。C++部分如下所示:C++jmethodIDjDec=env->GetStaticMethodID(cls,"dec","(I)V");jme

C++ 可变参数模板特化(和 static_assert)

是否可以专门化此模板声明:templateTYPEFoo(ARGS...args){static_assert(false);}我尝试了一些事情,例如:templateintFoo(floatargs){return42;}...但是当我尝试这样使用它时,我总是会遇到静态断言:autovalue=Foo(1.5f);正确的语法是什么? 最佳答案 您不得编写仅在未实例化时才有效的模板。这与标准中的以下规则相冲突:Ifnovalidspecializationcanbegeneratedforatemplate,andthattempl

c++ - 引用模板参数类型的 static_assert

我正在尝试做的是这个简单的模板钳制功能。我想确保upper>=lower在运行时和编译时。templateTclamp(constT&lower,constT&upper,constT&n){weak_assert(upper>=lower);returnstd::max(lower,std::min(n,upper));}这样写似乎合理:static_assert(upper>=lower,"invalidbounds");但是,当使用非constexpr调用时参数,编译器给我这个:Static_assertexpressionisnotanintegralconstantexpre

java - 有什么方法可以通过 JNI 获取指向 Java 数组的直接指针吗?

我需要通过JNI获取包含Java数组的直接内存地址的指针,而不调用某种复制(即直接访问)。GetArrayElements返回指向复制数组的指针-我需要能够直接从native层修改Java层上的int[]。从jintArray转换为int*成功返回内存地址,但我不确定这是否特别稳定...?这里有什么我可以做的吗...? 最佳答案 您可以使用直接内存(具有native字节顺序)的IntBuffer。在JNI中,您可以将地址用作指针。在Java中,您必须使用get()和put()。 关于ja

c++ - 对模板中的所有其他类型执行 static_assert

如何对模板中的所有其他类型执行static_assert(或其他检查)?template//T1,T2,T3,...structfoo{//HowcanI//forT1,T3,T5,T7,...//dosomechecks,forexample://static_assert(std::is_default_constructible::value,"invalidtype");//static_assert(std::is_copy_constructible::value,"invalidtype");}; 最佳答案 请试试这个

c++ - 如何仅在实际使用成员模板时才在成员模板中进行 static_assert?

考虑这个简单的类:templateclassFoo{public:Foo(Tconst&val):_val(val){}templateFoo(Fooconst&){static_assert(false,"CannotconvertfromFootoFoo.");}operatorT&(){return_val;}operatorTconst&()const{return_val;}private:T_val;};它允许从模板类型隐式构造并隐式转换回该类型,一个简单的包装器。现在,我不想启用不相关的Foo之间的转换,由于这些隐式构造/转换,这是可能的。我可以将模板化复制构造函数设为私

c++ - 带 static_assert() 的逗号运算符

当尝试使用static_assert作为参数来计算逗号运算符时编译失败voidfvoid(){}intmain(){inta=(1,2);//a=2intb=(fvoid(),3);//b=3intd=(,5);//^//error:expectedprimary-expressionbefore','token.OKintc=(static_assert(true),4);//^~~~~~~~~~~~~//error:expectedprimary-expressionbefore'static_assert'.Why?}看起来static_assert()在编译后甚至没有解析为vo

c++11:为什么 std::forward 中的 static_assert 是必需的?

在move.h中,forward有两个重载templateconstexpr_Tp&&forward(typenamestd::remove_reference::type&__t)noexcept{returnstatic_cast(__t);}templateconstexpr_Tp&&forward(typenamestd::remove_reference::type&&__t)noexcept{static_assert(!std::is_lvalue_reference::value,"templateargumentsubstituting_Tpisanlvalueref