概述
jvm 在创建thread的时候会create_stack_guard_pages()来保护我们的线程栈不能超过指定的大小,如果不对栈做限制的话,一旦其超过了为其分配的大小后,将会覆盖后面内存的数据将会产生意想不到的结果,所以jvm使用了stack_guard_pages来做限制。下面以JVM创建 mainThread流程举例(不同的Thread guard page不一样,见倒数第二张图)。看图吧:
调用mprotect函数使得指定内存区域不能被访问,一旦被访问内核将会发送一个SIGSEGV信号给进程
在jvm启动的时候会注册jvm需要处理的信号其中就包括了SIGSEGV
当jvm接收到相应的信号时会调用JVM_handle_linux_signal函数来处理信号(JVM_handle_linux_signal这是一个非常重要的函数,hotspot很多功能特性都是基于捕获内核信号来实现的(最后一张图)。参考:https://www.oracle.com/java/technologies/javase/signals.html)
这里的处理逻辑分了in_stack_yellow_zone还是in_stack_red_zone (第二张图中第四行代码可以得知gurad page 包含了两部分yellow_zone和red_zone ),如果是in_stack_yellow_zone,只是简单地抛出stack overflow exception,如果是in_stack_red_zone,那么意味着不可恢复的异常,程序会挂掉。下图是stack的内存布局(Creating guard page is very expensive. Java thread has HotSpot
guard page, only enable glibc guard page for non-Java thread)
https://www.oracle.com/java/technologies/javase/signals.html
最后
以上就是平常小鸭子为你收集整理的stack guard page for java的全部内容,希望文章能够帮你解决stack guard page for java所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复