使用C語言判斷棧的方向實例
這一問題主要是如何判讀出先后入棧的變量的地址大小,比如有a, b兩個變量一先一后被定義,如果a的地址大于b的地址,則說明是以低地址方向增長的,反之,往高地址方向增長。在寫C程序的時候不能簡單直接的定義兩個變量來比較它們的地址大小,因為這樣很有可能編譯器會做優(yōu)化,最終導致結果不真實。為避免這種編譯器優(yōu)化的情況,可以采用將變量定義到函數中,然后遞歸調用該函數。
例如下面的代碼:
#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語言判斷棧的方向實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持我們。
您可能感興趣的文章
- 04-02c語言函數調用后清空內存 c語言調用函數刪除字符
- 04-02c語言的正則匹配函數 c語言正則表達式函數庫
- 04-02func函數+在C語言 func函數在c語言中
- 04-02c語言中對數函數的表達式 c語言中對數怎么表達
- 04-02c語言用函數寫分段 用c語言表示分段函數
- 04-02c語言編寫函數冒泡排序 c語言冒泡排序法函數
- 04-02c語言沒有round函數 round c語言
- 04-02c語言分段函數怎么求 用c語言求分段函數
- 04-02C語言中怎么打出三角函數 c語言中怎么打出三角函數的值
- 04-02c語言調用函數求fibo C語言調用函數求階乘


閱讀排行
本欄相關
- 04-02c語言函數調用后清空內存 c語言調用
- 04-02func函數+在C語言 func函數在c語言中
- 04-02c語言的正則匹配函數 c語言正則表達
- 04-02c語言用函數寫分段 用c語言表示分段
- 04-02c語言中對數函數的表達式 c語言中對
- 04-02c語言編寫函數冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數 round c語言
- 04-02c語言分段函數怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數 c語言中怎
- 04-02c語言調用函數求fibo C語言調用函數求
隨機閱讀
- 01-11ajax實現頁面的局部加載
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10C#中split用法實例總結
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05dedecms(織夢)副欄目數量限制代碼修改
- 01-10delphi制作wav文件的方法
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 04-02jquery與jsp,用jquery