你可以用這個
static局部變量
普通的局部變量在棧空間上分配,這個局部變量所在的函數被多次調用時,每次調用這個局部變量在棧上的位置都不一定相同。局部變量也可以在堆上動態分配,但是記得使用完這個堆空間后要釋放之。
static局部變量中文名叫靜態局部變量。它與普通的局部變量比起來有如下幾個區別:
1)位置:靜態局部變量被編譯器放在全局存儲區.data(注意:不在.bss段內)),所以它雖然是局部的,但是在程序的整個生命周期中存在。
2)訪問權限:靜態局部變量只能被其作用域內的變量或函數訪問。也就是說雖然它會在程序的整個生命周期中存在,由于它是static的,它不能被其他的函數和源文件訪問。
3)值:靜態局部變量如果沒有被用戶初始化,則會被編譯器自動賦值為0,以后每次調用靜態局部變量的時候都用上次調用后的值。這個比較好理解,每次函數調用靜態局部變量的時候都修改它然后離開,下次讀的時候從全局存儲區讀出的靜態局部變量就是上次修改后的值。
以下是一些示例程序:
file1.h如下:
#include <stdio.h>
void printStr();
file1.c的內容如下:
#include "file1.h"
void printStr()
{
int normal = 0;
static int stat = 0; //this is a static local var
printf("normal = %d ---- stat = %d\n",normal, stat);
normal++;
stat++;
}
為了便于比較,我定義了兩個變量:普通局部變量normal和靜態局部變量stat,它們都被賦予初值0;
file2.c中調用file1.h:
#include "file1.h"
int main()
{
printStr();
printStr();
printStr();
printStr();
printf("call stat in main: %d\n",stat);
return 0;
}
復制代碼
這個調用會報錯,因為file2.c中引用了file1.c中的靜態局部變量stat,如下:
[liujx@server235 static]$ gcc -Wall file2.c file1.c -o file2
file2.c: In function ‘main’:
file2.c:9: 錯誤:‘stat’ 未聲明 (在此函數內第一次使用)
file2.c:9: 錯誤:(即使在一個函數內多次出現,每個未聲明的標識符在其
file2.c:9: 錯誤:所在的函數內只報告一次。)
編譯器說stat未聲明,這是因為它看不到file1.c中的stat,下面注掉這一行:
#include "file1.h"
int main()
{
printStr();
printStr();
printStr();
printStr();
// printf("call stat in main: %d\n",stat);
return 0;
}
liujx@server235 static]$ gcc -Wall file2.c file1.c -o file2
[liujx@server235 static]$ ./file2
normal = 0 ---- stat = 0
normal = 0 ---- stat = 1
normal = 0 ---- stat = 2
normal = 0 ---- stat = 3
運行如上所示。可以看出,函數每次被調用,普通局部變量都是重新分配,而靜態局部變量保持上次調用的值不變。
需要注意的是由于static局部變量的這種特性,使得含靜態局部變量的函數變得不可重入,即每次調用可能會產生不同的結果。這在多線程編程時可能會成為一種隱患。需要多加注意。
|