亚洲春色中文字幕久久久-三上亚,一吻二脱三床四吻胸,国产真实伦对白视频全集,在线毛片观看,精品成品入口黄网,国产毛aⅴ片久久久,亚洲AV色香蕉一区二区三区老师,萧皇后A级艳片,色情日本视频更新,99久久亚洲精品日本无码

標題: 有個奇怪的想法 哪位高手有思路 請教一下 [打印本頁]

作者: dzbj    時間: 2018-11-18 00:01
標題: 有個奇怪的想法 哪位高手有思路 請教一下
c51單片機里我看到和用到的變量分兩種 一種是全局變量 一種是函數(shù)內(nèi)部的臨時變量 前者任何時候都占用內(nèi)存 后者只有進入函數(shù)才占用 執(zhí)行完畢即銷毀

要請教的是 有什么方法能在使用一個函數(shù)時建立變量 運行若干次后 銷毀 因為這個函數(shù)在起作用的時候可能不止進入一次 臨時變量的值在離開函數(shù)后保存不了 如果用一個全局變量做轉(zhuǎn)儲那就和直接用全局變量沒區(qū)別了

作者: angmall    時間: 2018-11-18 07:14
你可以用這個

static局部變量
      普通的局部變量在棧空間上分配,這個局部變量所在的函數(shù)被多次調(diào)用時,每次調(diào)用這個局部變量在棧上的位置都不一定相同。局部變量也可以在堆上動態(tài)分配,但是記得使用完這個堆空間后要釋放之。

       static局部變量中文名叫靜態(tài)局部變量。它與普通的局部變量比起來有如下幾個區(qū)別:

           1)位置:靜態(tài)局部變量被編譯器放在全局存儲區(qū).data(注意:不在.bss段內(nèi))),所以它雖然是局部的,但是在程序的整個生命周期中存在。

           2)訪問權(quán)限:靜態(tài)局部變量只能被其作用域內(nèi)的變量或函數(shù)訪問。也就是說雖然它會在程序的整個生命周期中存在,由于它是static的,它不能被其他的函數(shù)和源文件訪問。

           3)值:靜態(tài)局部變量如果沒有被用戶初始化,則會被編譯器自動賦值為0,以后每次調(diào)用靜態(tài)局部變量的時候都用上次調(diào)用后的值。這個比較好理解,每次函數(shù)調(diào)用靜態(tài)局部變量的時候都修改它然后離開,下次讀的時候從全局存儲區(qū)讀出的靜態(tài)局部變量就是上次修改后的值。
以下是一些示例程序:

file1.h如下:

#include <stdio.h>
void printStr();


file1.c的內(nèi)容如下:
#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和靜態(tài)局部變量stat,它們都被賦予初值0;

file2.c中調(diào)用file1.h:

#include "file1.h"
int main()
{
printStr();
printStr();
printStr();
printStr();
printf("call stat in main: %d\n",stat);
return 0;
}
復(fù)制代碼
這個調(diào)用會報錯,因為file2.c中引用了file1.c中的靜態(tài)局部變量stat,如下:

[liujx@server235 static]$ gcc -Wall file2.c file1.c -o file2
file2.c: In function ‘main’:
file2.c:9: 錯誤:‘stat’ 未聲明 (在此函數(shù)內(nèi)第一次使用)
file2.c:9: 錯誤:(即使在一個函數(shù)內(nèi)多次出現(xiàn),每個未聲明的標識符在其
file2.c:9: 錯誤:所在的函數(shù)內(nèi)只報告一次。)

編譯器說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
運行如上所示。可以看出,函數(shù)每次被調(diào)用,普通局部變量都是重新分配,而靜態(tài)局部變量保持上次調(diào)用的值不變。

需要注意的是由于static局部變量的這種特性,使得含靜態(tài)局部變量的函數(shù)變得不可重入,即每次調(diào)用可能會產(chǎn)生不同的結(jié)果。這在多線程編程時可能會成為一種隱患。需要多加注意。


作者: diy1997    時間: 2018-11-18 09:21
我們只是在別人規(guī)定的框架里做應(yīng)用開發(fā)設(shè)計。


作者: dzbj    時間: 2018-11-18 13:51
angmall 發(fā)表于 2018-11-18 07:14
你可以用這個

static局部變量

static這個關(guān)鍵字我用過 但不知道怎么能在不用的時候釋放內(nèi)存 水平還是不夠啊 前輩能給個簡單的范例么
作者: dzbj    時間: 2018-11-18 13:53
diy1997 發(fā)表于 2018-11-18 09:21
我們只是在別人規(guī)定的框架里做應(yīng)用開發(fā)設(shè)計。

你說的是 但也許有高人可以繞開 就像51的操作系統(tǒng) 有高人看原配的不爽就自己寫了一個 雖然碰上這種神人要靠運氣 我還是想試試自己的運氣
作者: trueman007    時間: 2018-11-18 15:51
靜態(tài)變量static就是干這個的
作者: 浮念    時間: 2018-11-18 17:34
你可以用這個

static局部變量
      普通的局部變量在棧空間上分配,這個局部變量所在的函數(shù)被多次調(diào)用時,每次調(diào)用這個局部變量在棧上的位置都不一定相同。局部變量也可以在堆上動態(tài)分配,但是記得使用完這個堆空間后要釋放之。

       static局部變量中文名叫靜態(tài)局部變量。它與普通的局部變量比起來有如下幾個區(qū)別:

           1)位置:靜態(tài)局部變量被編譯器放在全局存儲區(qū).data(注意:不在.bss段內(nèi))),所以它雖然是局部的,但是在程序的整個生命周期中存在。

           2)訪問權(quán)限:靜態(tài)局部變量只能被其作用域內(nèi)的變量或函數(shù)訪問。也就是說雖然它會在程序的整個生命周期中存在,由于它是static的,它不能被其他的函數(shù)和源文件訪問。

           3)值:靜態(tài)局部變量如果沒有被用戶初始化,則會被編譯器自動賦值為0,以后每次調(diào)用靜態(tài)局部變量的時候都用上次調(diào)用后的值。這個比較好理解,每次函數(shù)調(diào)用靜態(tài)局部變量的時候都修改它然后離開,下次讀的時候從全局存儲區(qū)讀出的靜態(tài)局部變量就是上次修改后的值。
以下是一些示例程序:

file1.h如下:

#include <stdio.h>
void printStr();


file1.c的內(nèi)容如下:
#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和靜態(tài)局部變量stat,它們都被賦予初值0;

file2.c中調(diào)用file1.h:

#include "file1.h"
int main()
{
printStr();
printStr();
printStr();
printStr();
printf("call stat in main: %d\n",stat);
return 0;
}
復(fù)制代碼
這個調(diào)用會報錯,因為file2.c中引用了file1.c中的靜態(tài)局部變量stat,如下:

[liujx@server235 static]$ gcc -Wall file2.c file1.c -o file2
file2.c: In function ‘main’:
file2.c:9: 錯誤:‘stat’ 未聲明 (在此函數(shù)內(nèi)第一次使用)
file2.c:9: 錯誤:(即使在一個函數(shù)內(nèi)多次出現(xiàn),每個未聲明的標識符在其
file2.c:9: 錯誤:所在的函數(shù)內(nèi)只報告一次。)

編譯器說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
運行如上所示。可以看出,函數(shù)每次被調(diào)用,普通局部變量都是重新分配,而靜態(tài)局部變量保持上次調(diào)用的值不變。

需要注意的是由于static局部變量的這種特性,使得含靜態(tài)局部變量的函數(shù)變得不可重入,即每次調(diào)用可能會產(chǎn)生不同的結(jié)果。這在多線程編程時可能會成為一種隱患。需要多加注意。
作者: dzbj    時間: 2018-11-18 22:09
浮念 發(fā)表于 2018-11-18 17:34
你可以用這個

static局部變量

看說明 好像和理想狀態(tài)不一樣

"1)位置:靜態(tài)局部變量被編譯器放在全局存儲區(qū).data(注意:不在.bss段內(nèi))),所以它雖然是局部的,但是在程序的整個生命周期中存在。"

它在程序的整個生命周期中存在 我試過這個也是這樣 如果聲明成靜態(tài)變量 內(nèi)存會增加 而且不會被釋放 實際上在我的實驗里 在函數(shù)內(nèi)部聲明static和在開始直接聲明在內(nèi)存數(shù)上沒什么區(qū)別




歡迎光臨 (http://www.denmoz.com/bbs/) Powered by Discuz! X3.1