调用 longjmp() 后,如果非 volatile 限定的本地对象的值在调用 setjmp() 后可能已更改,则不应访问它们。在这种情况下,它们的值被认为是不确定的,访问它们是未定义的行为。
现在我的问题是为什么 volatile 在这种情况下有效?那个 volatile 变量的变化不会仍然使 longjmp 失败吗?例如,在下面给出的示例中,longjmp 将如何正常工作?当代码在 longjmp 之后返回到 setjmp 时,local_var 的值不会是 2 而不是 1 吗?
void some_function()
{
volatile int local_var = 1;
setjmp( buf );
local_var = 2;
longjmp( buf, 1 );
}