#include <unistd.h> #include <stdio.h> #include <stdlib.h> #include <setjmp.h> static jmp_buf jmpbuf; static int globval = 1; static void func2(void) { longjmp(jmpbuf, 1); } static void func1(int i, int j, int k, int l) { fprintf(stdout, "in func1:\n"); fprintf(stdout, "globval = %d," "autoval = %d," "regival = %d," "volaval = %d," "statval = %d\n", globval, i, j, k , l); func2(); } int main(int argc, char* argv[]) { int autoval = 2; register int regival = 3; volatile int volaval = 4; static int statval = 5; if (setjmp(jmpbuf) != 0) { fprintf(stdout, "after longjmp:\n"); fprintf(stdout, "globval = %d," "autoval = %d," "regival = %d," "volaval = %d," "statval = %d\n", globval, autoval, regival, volaval, statval); exit(0); } globval = 95; autoval = 96; regival = 97; volaval = 98; statval = 99; func1(autoval, regival, volaval, statval); exit(0); }
編譯時不進行優化,結果以下:函數
in func1: globval = 95,autoval = 96,regival = 97,volaval = 98,statval = 99 after longjmp: globval = 95,autoval = 96,regival = 97,volaval = 98,statval = 99
編譯時進行所有優化,結果以下:佈局
in func1: globval = 95,autoval = 96,regival = 97,volaval = 98,statval = 99 after longjmp: globval = 95,autoval = 2,regival = 3,volaval = 98,statval = 99
咱們能夠看到:全局、靜態、易失變量不受優化的影響,在調用longjmp以後,他們的值是最近所呈現的值優化
未優化時,全部5個變量都存放在存儲器中,而進行優化以後,autoval 和 regival 都存放在寄存器中,而 volatile變量仍存放在 存儲器中spa
對於 volatile 修飾符用法,這裏有一篇很好的文章:http://hedengcheng.com/?p=725命令行