求救,调用GetStringUTFChars导致JVM crash

sunmoonkkk 2011-05-06 04:09:48
JNI不是很熟,请高手指点下如何定位/debug,多谢!!!

JNI代码实现如下:

--------------------------------------------------------------------------------------------
JNIEXPORT jint JNICALL Java_client_common_ClientJNI_GetPolicy
(JNIEnv * env, jclass cl, jstring login_name, jstring ip_addr, jobject obj)
{
std::cout << "===============GetPolicy." << std::endl;
const char * c_username = env->GetStringUTFChars(login_name, NULL);
if (NULL == c_username) {
std::cout << "Failed to get user name." << std::endl;
return -1;
}
const char * c_address = env->GetStringUTFChars(ip_addr, NULL);
if (NULL == c_address ) {
std::cout << "Failed to get address." << std::endl;
env->ReleaseStringUTFChars(login_name, c_username);
return -1;
}

// 访问数据库,根据c_username 和 c_address 读取数据....

env->ReleaseStringUTFChars(login_name, c_username);
env->ReleaseStringUTFChars(ip_addr, c_address);
return 0;
}

--------------------------------------------------------------------------------------------

tomcat里的Java程序会调用这个方法,一个连接时没有问题。当同时20个连接访问的时候,JVM发生了crash。
tomcat 的catalina.out:
--------------------------------------------------------------------------------------------
INFO: Server startup in 1481 ms
===============GetPolicy.
//前面多个访问正常,然后突然就歇菜了...
===============GetPolicy.
#
# A fatal error has been detected by the Java Runtime Environment:
#
# SIGSEGV (0xb) at pc=0xf7af14f8, pid=8715, tid=4088118160
#
# JRE version: 6.0_23-b05
# Java VM: Java HotSpot(TM) Client VM (19.0-b09 mixed mode, sharing linux-x86 )
# Problematic frame:
# V [libjvm.so+0x4324f8]
#
# An error report file with more information is saved as:
# /var/hs_err_pid8715.log
#
# If you would like to submit a bug report, please visit:
# http://java.sun.com/webapps/bugreport/crash.jsp
#
--------------------------------------------------------------------------------------------

/var/hs_err_pid8715.log文件很长,部分内容:

--------------------------------------------------------------------------------------------
Register to memory mapping:

EAX=0x6c717370
0x6c717370 is pointing to unknown location

EBX=0xf7b930b0
0xf7b930b0: <offset 0x4d40b0> in /usr/iwss/AdminUI/jre/lib/i386/client/libjvm.so at 0xf76bf000

ECX=0x00000000
0x00000000 is pointing to unknown location

EDX=0x6c717370
0x6c717370 is pointing to unknown location

...

Stack: [0xf3a6b000,0xf3abc000], sp=0xf3aba138, free space=316k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
V [libjvm.so+0x4324f8]
V [libjvm.so+0x238a7b]
V [libjvm.so+0x238b15]
V [libjvm.so+0x260759]
C [libRClientJNI.so+0x243c8] _ZN10_Jv_JNIEnv12NewStringUTFEPKc+0x1c
C [libRClientJNI.so+0x23e48] Java_client_common_ClientJNI_GetPolicy+0x5a4
j client.common.ClientJNI.GetPolicy(Ljava/lang/String;Ljava/lang/String;Ljava/lang/ObjectI+0
--------------------------------------------------------------------------------------------

多谢!
...全文
605 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
安心逍遥 2011-05-06
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 wang12 的回复:]
内存溢出。看看你的jni调用的资源释放是不是合理
[/Quote]
wang12 2011-05-06
  • 打赏
  • 举报
回复
内存溢出。看看你的jni调用的资源释放是不是合理
【更新至2025年】2001-2025年上市公司数字化转型年报词频统计(吴非、赵宸宇、甄红线)(300+年报词频统计) 1、时间:2001-2025年 2、来源:上市公司年报 3、参考文献:企业数字化转型与资本市场表现——来自股票流动性的经验证据(吴非) 数字化转型如何影响企业全要素生产率(赵宸宇) 知识产权行政保护与企业数字化转型(甄红线) 4、方法说明:(1)参考吴非老师的做法,对人工智能技术、大数据技术、云计算技术、区块链技术、数字技术运用五个维度76个数字化相关词频进行统计 (2)参考赵宸宇老师的做法,对数字技术应用、互联网商业模式、智能制造、现代信息系统四个维度99个数字化相关词频进行统计 (3)参考甄红线老师的做法,对技术分类、组织赋能、数字化应用等类别下139个数字化相关词频进行统计 5、指标:年份、股票代码、公司简称、行业名称、行业代码、全文-文本总长度、仅中英文-文本总长度、人工智能技术-吴、大数据技术-吴、云计算技术-吴、区块链技术-吴、数字技术运用-吴、数字技术应用-赵、互联网商业模式-赵、智能制造-赵、现代信息系统-赵、技术分类-人工智能技术-甄、技术分类-区块链技术-甄、技术分类-云计算技术-甄、技术分类-大数据技术-甄、组织赋能-人工智能技术-甄、组织赋能-云计算技术-甄、组织赋能-大数据技术-甄、组织赋能-广义数字技术-甄、数字化应用-技术创新-甄、数字化应用-流程创新-甄、数字化应用-业务创新-甄、人工智能、商业智能、图像理解、投资决策辅助系统、智能数据分析、智能机器人、机器学习、深度学习、语义搜索、生物识别技术、人脸识别、语音识别、身份验证、自动驾驶、自然语言处理、大数据、数据挖掘、文本挖掘、数据可视化、异构数据、征信、增强现实、混合现实、虚拟现实、云计算、流计算、图计算、内存计算、多方安全计算、类脑计算、绿色计算、认知计算等300+词频

81,111

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧