我有以下代码来返回对象数组,对象数组中填充了基元类型的结构元素,我不知道如何将基元类型转换为jobject,然后使用SetObjectArrayElement方法设置为ObjectArray,
下面是我的C结构信息
struct cheqdtl {
unsigned long irno;
char bank_accno1 [16];
unsigned long bank_id;
unsigned long outlet_id;
char bank_accno [16];
char cheque_num [41];
double deposit_amt;
char chq_date [4]; };
我的JNI代码
JNIEXPORT jobjectArray JNICALL Java_nativeclass_Jmain_getChequeList (JNIEnv *env,jobject jobj,jint ch,jstring benAccNo,jstring fromDate,jstring toDate){
clientlist *cl = new clientlist();
ShortInt lcount = 0;
int i;
jmp_buf jmpb;
const char *ben_acc_no = env->GetStringUTFChars(benAccNo, NULL);
const char *from_date = env->GetStringUTFChars(fromDate, NULL);
const char *to_date = env->GetStringUTFChars(toDate, NULL);
struct b_date f_date, t_date;
char temp_date[10];
mov_mem((char *)from_date, temp_date, 2);
temp_date[2] = '\0';
f_date.day = atoi(temp_date);
mov_mem((char *)from_date + 3, temp_date, 2);
temp_date[2] = '\0';
f_date.month = atoi(temp_date);
mov_mem((char *)from_date+6, temp_date, 4);
temp_date[4] = '\0';
f_date.year = atoi(temp_date);
mov_mem((char *)to_date, temp_date, 2);
temp_date[2] = '\0';
t_date.year = atoi(temp_date);
mov_mem((char *)to_date + 3, temp_date, 2);
temp_date[2] = '\0';
t_date.month = atoi(temp_date);
mov_mem((char *)to_date + 6, temp_date, 4);
temp_date[4] = '\0';
t_date.year = atoi(temp_date);
struct cheqdtl *cq_dtl = NULL;
cq_dtl = (struct cheqdtl *)malloc( sizeof( struct cheqdtl) );
cl->get_cheque_list((int)ch,(char *)ben_acc_no, &f_date, &t_date, &cq_dtl, &lcount);
jclass objCls= env->FindClass("java/lang/Object");
if( objCls == NULL )
return NULL;
jobjectArray outObjArr = env->NewObjectArray( lcount, objCls, NULL );
jmethodID jobjConstrId = env->GetMethodID( objCls, "<init>", "()V" );
if( jobjConstrId == 0)
return NULL;
jobjectArray rowObjArr ;
if( !lcount )
return NULL;
for( i = 0; i < lcount; ++i ) {
rowObjArr = env->NewObjectArray(8, objCls, NULL);
cout<<"\n Get Array Length:- "<<env->GetArrayLength(rowObjArr)<<endl;
std::cout<<cq_dtl[i].irno<<"\n";
std::cout<<cq_dtl[i].bank_accno1<<"\n";
std::cout<<cq_dtl[i].bank_id<<"\n";
std::cout<<cq_dtl[i].outlet_id<<"\n";
std::cout<<cq_dtl[i].bank_accno<<"\n";
std::cout<<cq_dtl[i].cheque_num<<"\n";
std::cout<<cq_dtl[i].deposit_amt<<"\n";
std::cout<<cq_dtl[i].chq_date<<"\n";
env->SetObjectArrayElement(rowObjArr, 0, (jobject) cq_dtl[i].irno);
env->SetObjectArrayElement(rowObjArr, 1, (jobject) cq_dtl[i].bank_accno1);
env->SetObjectArrayElement(rowObjArr, 2, (jobject) cq_dtl[i].bank_id);
env->SetObjectArrayElement(rowObjArr, 3, (jobject) cq_dtl[i].outlet_id);
env->SetObjectArrayElement(rowObjArr, 4, (jobject) cq_dtl[i].bank_accno);
env->SetObjectArrayElement(rowObjArr, 5, (jobject) cq_dtl[i].cheque_num);
env->SetObjectArrayElement(rowObjArr, 6, (jobject) cq_dtl[i].deposit_amt);
env->SetObjectArrayElement(rowObjArr, 7, (jobject) cq_dtl[i].chq_date);
if( rowObjArr )
env->SetObjectArrayElement( outObjArr, i, rowObjArr );
env->DeleteLocalRef( rowObjArr );
}
env->DeleteLocalRef( objCls );
free( cq_dtl );
delete cl;
return outObjArr; }
A fatal error has been detected by the Java Runtime Environment:
写入核心转储失败。核心转储已被禁用。要启用核心转储,请在再次启动Java之前尝试“ulimit-c unlimited”
包含更多信息的错误报告文件保存为:/data1/home/user1/myname/myproject/hs_err_pid4754.log
如果您想提交bug报告,请访问:http://bugreport.sun.com/bugreport/crash.jsp
您不能通过简单地转换为JObject
来实现这一点。C++完全没有java自动装箱的知识。您将需要手动实例化适当的java对象。
例如,IRNO
需要转换为java Long类的实例(假设是64位操作系统)。为此,您需要:
irno
作为参数传递给具有newobjecta的构造函数来创建新的java长对象我正在创建一个由数组支持的泛型类型堆栈。当我尝试创建泛型类型数组时,Java不允许我这样做。有人告诉我,我必须创建一个类型为Object的数组,并将其转换为泛型类型。我已经将对象数组转换为类型,但如何处理Java不断给我的未检查类型错误? 这就是我目前所处的位置。 更新:我正在创建一个对象数组,然后在方法的末尾将返回类型转换为T类型。
问题内容: 好吧,如果我有这段代码 一切正常,但是 运行后给出以下错误(Eclipse没有给出任何错误) 虽然,当我这样做 要么 再没有错了。 为什么必须将其首先转换? 问题答案: 声明对象时,可以通过检查对象是否实际上已强制转换为实例来判断。由于取消装箱约定,可以再次将其强制转换为。之后,该值可以转换为。 但是,没有从Double实例转换为的取消装箱约定,因此,如果您尝试这样做,则运行时将发出。
我有一个类型 现在我想做这样的事情。 如何将我的 转换为基元类型? 它给我的错误是: 将“Rating”类型转换为“number”类型可能是错误的,因为这两种类型都没有充分重叠。如果这是有意的,首先将表达式转换为“未知” 我已经经历过了,但我想要的是它的反面 编辑: tsconfig.json tsc版本:3.2.1
主要内容:强制对象类型转换将一个类型强制转换成另一个类型的过程被称为类型转换。本节所说的 对象类型转换,是指存在继承关系的对象,不是任意类型的对象。当对不存在继承关系的对象进行强制类型转换时,会抛出 Java 强制类型转换(java.lang.ClassCastException)异常。 Java 语言允许某个类型的引用变量引用子类的实例,而且可以对这个引用变量进行类型转换。Java 中引用类型之间的类型转换(前提是两个类
问题内容: 我正在使用返回“对象”类型的普通对象的Web服务。调试清楚地表明此对象中存在某种Array,因此我想知道如何将“ Object”转换为Array(或类似对象)? 我尝试了以下方法: 但是没有任何效果。我总是得到一个InvocationTargetException。 我究竟做错了什么? 编辑 : 可悲的是,我不得不删除指向显示Eclipse调试器输出的图像的链接,因为它不再可用。请不要
问题内容: 在Java中,从Object转换为其他类型时,为什么第二行会产生与转换相关的警告,而第一行却没有? 问题答案: 这是因为在执行时,由于 类型Erase 不会 真正 检查对象是否为a 。真的只是将其投射到。例如: __ 有关更多信息,请参见Angelika Langer的Java泛型常见问题解答 ,尤其是类型擦除部分。