這一問題主要是如何判讀出先后入棧的變量的地址大小,比如有a, b兩個變量一先一后被定義,如果a的地址大于b的地址,則說明是以低地址方向增長的,反之,往高地址方向增長。在寫C程序的時候不能簡單直接的定義兩個變量來比較它們的地址大小,因為這樣很有可能編譯器會做優化,最終導致結果不真實。為避免這種編譯器優化的情況,可以采用將變量定義到函數中,然后遞歸調用該函數。
例如下面的代碼:
#include <stdio.h>static int stack_direction = 0;static void FindStackDirection(){ static char *addr = NULL; auto char dummy; if (NULL == addr) { addr = &dummy; FindStackDirection(); //遞歸調用,讓dummy兩次被定義,并一先一后入棧 } else { if (&dummy > addr) { //兩次地址相比較,后入棧的dummy地址大于先前的地址則說明是往高地址增長 stack_direction = 1; } else { stack_direction = -1; } }}int main(int argc, char const *argv[]){ FindStackDirection(); if (1 == stack_direction) { puts("stack grew upward"); } else { puts("stack grew downward"); } return 0;}
以上這篇使用C語言判斷棧的方向實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。
新聞熱點
疑難解答
圖片精選