忘记密码   免费注册 查看新帖 |

ChinaUnix.net

  平台 论坛 博客 文库 频道自动化运维 虚拟化 储存备份 C/C++ PHP MySQL 嵌入式 Linux系统
最近访问板块 发新帖
查看: 1922 | 回复: 4

[其他] java loadLibrary 崩溃 [复制链接]

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
发表于 2015-07-01 19:07 |显示全部楼层
不知什么毛病, 也不是找不到 so, 我故意改名字, 发现 android 报告找不到, 改回去, 倒是不报了, 直接崩溃
01-01 09:14:45.781  18025-18025/libmm.demo1 I/zylthinking﹕ fuck loadlibrary crash
01-01 09:14:45.781  18025-18025/libmm.demo1 D/dalvikvm﹕ Trying to load lib /data/app-lib/libmm.demo1-2/libmm.so 0x4216ae58
01-01 09:14:45.781  18025-18025/libmm.demo1 I/linker﹕ [ Done calling function @ 0x6011eef0 for 'libmm.so' ]
01-01 09:14:45.789  18025-18025/libmm.demo1 A/libc﹕ Fatal signal 11 (SIGSEGV) at 0xdeadbaad (code=1), thread 18025 (libmm.demo1)
01-01 09:14:45.890      122-122/? I/DEBUG﹕ *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
01-01 09:14:45.890      122-122/? I/DEBUG﹕ Build fingerprint: 'google/yakju/maguro:4.3/JWR66Y/776638:user/release-keys'
01-01 09:14:45.890      122-122/? I/DEBUG﹕ Revision: '9'
01-01 09:14:45.890      122-122/? I/DEBUG﹕ pid: 18025, tid: 18025, name: libmm.demo1  >>> libmm.demo1 <<<
  
  
java 代码:   
   static {
         Log.i("zylthinking", "fuck loadlibrary crash");
         System.loadLibrary("mm");  --------------------- 在这里 crash
         Log.i("zylthinking", "fuckkkkkk4");
     }
  
以下函数没被调用, 应该是发生在调用前
jint JNI_OnLoad(JavaVM* vm, void* reserved)
{
     __android_log_print(ANDROID_LOG_INFO, "zylthinking", "what is thscscde fuck\n");

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
发表于 2015-07-01 20:08 |显示全部楼层
尼玛, 我将文件全部删除, 只留一个 jni 文件, 将全部 jni 函数实现为空函数, 发现不崩了;
然后这个 jni 文件不变; 将删除的源码重新加回来, 理论上只是多编译了 + 链接一些文件是吧, 最多不过增大了 so 的体积而已; 永远不会被调到, 再测一下, 崩了
  
就不知什么玩意了

论坛徽章:
42
15-16赛季CBA联赛之辽宁
日期:2018-05-02 10:46:022016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:36每日论坛发贴之星
日期:2016-01-27 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:45程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之天津
日期:2016-11-02 00:33:12
发表于 2015-07-02 11:50 |显示全部楼层
回复 2# zylthinking


    搞不好里面有啥全局对象之类的初始化的时候崩了。

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
发表于 2015-07-02 15:00 |显示全部楼层
zylthinking fuck loadlibrary crash

这句是不是该这样翻译:
    zylthinking 把 loadlibrary 操翻了。。。

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
发表于 2015-07-02 16:24 |显示全部楼层
windoze 发表于 2015-07-02 11:50
回复 2# zylthinking


类似, 昨晚已经找到原因了, 我弄了这么一个函数, 不崩就怪了
static struct timespec base;

__attribute__((constructor))
static int timer_init(struct timespec* base)
{

    int n = clock_gettime(CLOCK_MONOTONIC, base);
    if (0 != n) {
        printf("timer_init failed\n");
        exit(-1);
    }
    return 0;
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号 北京市公安局海淀分局网监中心备案编号:11010802020122
广播电视节目制作经营许可证(京) 字第1234号 中国互联网协会会员  联系我们:wangnan@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP