使用C語言判斷棧的方向?qū)嵗?/h1>
更新時(shí)間:2016年12月29日 09:24:58 投稿:jingxian
下面小編就為大家?guī)硪黄褂肅語言判斷棧的方向?qū)嵗P【幱X得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧,祝大家游戲愉快哦
這一問題主要是如何判讀出先后入棧的變量的地址大小,比如有a, b兩個(gè)變量一先一后被定義,如果a的地址大于b的地址,則說明是以低地址方向增長的,反之,往高地址方向增長。在寫C程序的時(shí)候不能簡單直接的定義兩個(gè)變量來比較它們的地址大小,因?yàn)檫@樣很有可能編譯器會做優(yōu)化,最終導(dǎo)致結(jié)果不真實(shí)。為避免這種編譯器優(yōu)化的情況,可以采用將變量定義到函數(shù)中,然后遞歸調(diào)用該函數(shù)。
例如下面的代碼:
#include <stdio.h>
static int stack_direction = 0;
static void FindStackDirection()
{
static char *addr = NULL;
auto char dummy;
if (NULL == addr) {
addr = &dummy;
FindStackDirection(); //遞歸調(diào)用,讓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語言判斷棧的方向?qū)嵗褪切【幏窒斫o大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- C語言編程中建立和解除內(nèi)存映射的方法
- C語言輾轉(zhuǎn)相除法求2個(gè)數(shù)的最小公約數(shù)
- C語言從txt文件中逐行讀入數(shù)據(jù)存到數(shù)組中的實(shí)現(xiàn)方法
- c語言實(shí)現(xiàn)把文件中數(shù)據(jù)讀取并存到數(shù)組中
- 詳解C語言位域的使用與注意事項(xiàng)
- 利用C語言的Cairo圖形庫繪制太極圖實(shí)例教程
- C語言設(shè)計(jì)一個(gè)閃閃的圣誕樹
- 使用C語言編寫圣誕表白程序
- C語言實(shí)現(xiàn)返回字符串函數(shù)的四種方法
- C語言 棧的表示和實(shí)現(xiàn)詳細(xì)介紹
- C語言 經(jīng)典題目螺旋矩陣 實(shí)例詳解
- C語言 文件操作解析詳解及實(shí)例代碼
- C語言實(shí)現(xiàn)大數(shù)據(jù)文件的內(nèi)存映射機(jī)制
相關(guān)文章
-
C語言實(shí)現(xiàn)定時(shí)器控制LED燈閃爍
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)定時(shí)器控制LED燈閃爍,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下 2021-05-05
-
C/C++?Qt?數(shù)據(jù)庫QSql增刪改查組件應(yīng)用教程
Qt?SQL模塊是Qt中用來操作數(shù)據(jù)庫的類,該類封裝了各種SQL數(shù)據(jù)庫接口,可以很方便的鏈接并使用。本文主要介紹了Qt數(shù)據(jù)庫QSql增刪改查組件的應(yīng)用教程,感興趣的同學(xué)可以學(xué)習(xí)一下 2021-12-12
-
解決C++ fopen按行讀取文件及所讀取的數(shù)據(jù)問題
今天小編就為大家分享一篇解決C++ fopen按行讀取文件及所讀取的數(shù)據(jù)問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧 2018-07-07
-
詳解C++11 原始字符串字面量(Json字符串表達(dá)更方便)
原始字符串字面量(Raw String Literal)是C++11引入的一種字符串表示方式,用于簡化字符串的定義,特別是當(dāng)字符串中包含大量特殊字符(如換行符、雙引號等)時(shí),這篇文章給大家介紹C++11原始字符串字面量(Json字符串表達(dá)更方便)的相關(guān)知識,感興趣的朋友一起看看吧 2025-03-03
-
如何基于 Blueprint 在游戲中創(chuàng)建實(shí)時(shí)音視頻功能
我們在本文先來講講如何在 Unreal 中用 Blueprint 快速實(shí)現(xiàn)。稍后會分享基于 C++的實(shí)現(xiàn)步驟。感興趣的朋友跟隨小編一起看看吧
2020-05-05
-
C語言中計(jì)算函數(shù)執(zhí)行時(shí)間的三種方式
本文主要介紹了C語言中計(jì)算函數(shù)執(zhí)行時(shí)間的三種方式,主要包括clock(),timeb和time,具有一定的參考價(jià)值,感興趣的可以了解一下 2023-09-09
最新評論
這一問題主要是如何判讀出先后入棧的變量的地址大小,比如有a, b兩個(gè)變量一先一后被定義,如果a的地址大于b的地址,則說明是以低地址方向增長的,反之,往高地址方向增長。在寫C程序的時(shí)候不能簡單直接的定義兩個(gè)變量來比較它們的地址大小,因?yàn)檫@樣很有可能編譯器會做優(yōu)化,最終導(dǎo)致結(jié)果不真實(shí)。為避免這種編譯器優(yōu)化的情況,可以采用將變量定義到函數(shù)中,然后遞歸調(diào)用該函數(shù)。
例如下面的代碼:
#include <stdio.h> static int stack_direction = 0; static void FindStackDirection() { static char *addr = NULL; auto char dummy; if (NULL == addr) { addr = &dummy; FindStackDirection(); //遞歸調(diào)用,讓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語言判斷棧的方向?qū)嵗褪切【幏窒斫o大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- C語言編程中建立和解除內(nèi)存映射的方法
- C語言輾轉(zhuǎn)相除法求2個(gè)數(shù)的最小公約數(shù)
- C語言從txt文件中逐行讀入數(shù)據(jù)存到數(shù)組中的實(shí)現(xiàn)方法
- c語言實(shí)現(xiàn)把文件中數(shù)據(jù)讀取并存到數(shù)組中
- 詳解C語言位域的使用與注意事項(xiàng)
- 利用C語言的Cairo圖形庫繪制太極圖實(shí)例教程
- C語言設(shè)計(jì)一個(gè)閃閃的圣誕樹
- 使用C語言編寫圣誕表白程序
- C語言實(shí)現(xiàn)返回字符串函數(shù)的四種方法
- C語言 棧的表示和實(shí)現(xiàn)詳細(xì)介紹
- C語言 經(jīng)典題目螺旋矩陣 實(shí)例詳解
- C語言 文件操作解析詳解及實(shí)例代碼
- C語言實(shí)現(xiàn)大數(shù)據(jù)文件的內(nèi)存映射機(jī)制
相關(guān)文章
C語言實(shí)現(xiàn)定時(shí)器控制LED燈閃爍
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)定時(shí)器控制LED燈閃爍,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-05-05C/C++?Qt?數(shù)據(jù)庫QSql增刪改查組件應(yīng)用教程
Qt?SQL模塊是Qt中用來操作數(shù)據(jù)庫的類,該類封裝了各種SQL數(shù)據(jù)庫接口,可以很方便的鏈接并使用。本文主要介紹了Qt數(shù)據(jù)庫QSql增刪改查組件的應(yīng)用教程,感興趣的同學(xué)可以學(xué)習(xí)一下2021-12-12解決C++ fopen按行讀取文件及所讀取的數(shù)據(jù)問題
今天小編就為大家分享一篇解決C++ fopen按行讀取文件及所讀取的數(shù)據(jù)問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07詳解C++11 原始字符串字面量(Json字符串表達(dá)更方便)
原始字符串字面量(Raw String Literal)是C++11引入的一種字符串表示方式,用于簡化字符串的定義,特別是當(dāng)字符串中包含大量特殊字符(如換行符、雙引號等)時(shí),這篇文章給大家介紹C++11原始字符串字面量(Json字符串表達(dá)更方便)的相關(guān)知識,感興趣的朋友一起看看吧2025-03-03如何基于 Blueprint 在游戲中創(chuàng)建實(shí)時(shí)音視頻功能
我們在本文先來講講如何在 Unreal 中用 Blueprint 快速實(shí)現(xiàn)。稍后會分享基于 C++的實(shí)現(xiàn)步驟。感興趣的朋友跟隨小編一起看看吧2020-05-05C語言中計(jì)算函數(shù)執(zhí)行時(shí)間的三種方式
本文主要介紹了C語言中計(jì)算函數(shù)執(zhí)行時(shí)間的三種方式,主要包括clock(),timeb和time,具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09