程序员刘杨

———没有写不出的程序,只有不努力的程序员。

2016年05月18日   码农之路   3,547 次浏览

祝大家新年快乐,有任何问题可与我联系:点击这里给我发消息

java.lang.IllegalArgumentException : java.lang.ClassCastException@1c6d11a
java.lang.IllegalArgumentException : argument type mismatch
 
在服务器上发现了第一个错误,然后在本机调试时却只出现第二个错误,怎么也没法重现第一个错误,什么原因呢?
 
经过各种查找,终于发现原因如下:

When you invoke invokeMethod for the first time, JVM use a slower route, which is easier for programmers to debug (so it’s slower!), so it will show a more friendly argument type mismatch message when you passes a bad argument.

When you invoke invokeMethod for a lot of times (16 times are enough in my tests), JVM generated a GeneratedMethodAccessor*** in runtime, which is faster, with less error checking. So it will show such an ugly java.lang.ClassCastException@603a3e21 message when you passes a bad argument.

意思就是JVM在第一次持行某些方法(我这里是反射的相关方法)时,使用的是慢模式以方便程序员调试代码。但是当这个方法调用很多次(我这里反射的方法是调用16次)后,JVM就会使用快模式。慢模式和快模式下显示的错误是有可能不一样的。
参考资料:
http://stackoverflow.com/questions/16042591/reflections-illegalargumentexception-causes/16148430
赞 赏
申明:除非注明,本站文章均为原创,转载请以链接形式标明本文地址。 如有问题,请于一周内与本站联系,本站将在第一时间对相关内容进行处理。
本文地址: http://www.yyjjssnn.cn/articles/722.html

>>> Hello World <<<

这篇内容是否帮助到你了呢?

如果你有任何疑问或有建议留给其他朋友,都可以给我留言。

:wink: :twisted: :surprised: :smile: :smile9: :smile8: :smile7: :smile6: :smile5: :smile56: :smile55: :smile54: :smile53: :smile52: :smile51: :smile50: :smile4: :smile49: :smile48: :smile47: :smile46: :smile45: :smile44: :smile43: :smile42: :smile41: :smile40: :smile3: :smile39: :smile38: :smile37: :smile36: :smile35: :smile34: :smile33: :smile32: :smile31: :smile30: :smile2: :smile29: :smile28: :smile27: :smile26: :smile25: :smile24: :smile23: :smile22: :smile21: :smile20: :smile1: :smile19: :smile18: :smile17: :smile16: :smile15: :smile14: :smile13: :smile12: :smile11: :smile10: :smile0: :sad: :rolleyes1: :redface: :razz: :question: :neutral: :mrgreen: :mad: :lol: :idea: :exclaim: :evil: :eek: :cry: :cool: :confused: :biggrin: :arrow:

友情链接: 程序员刘杨 刘杨
Copyright 2003~2018 保留所有权利 | 网站地图
备案号:湘ICP备14001005号-2

湘公网安备 43011102001322号