被呼叫函式內部的區域性變數宣告為static型別

2021-06-01 13:06:41 字數 408 閱讀 6919

今天在工作中遇到了關於在被呼叫函式內部的區域性變數宣告為static型別的作用,做一下使用總結。

例如乙個被呼叫函式如getbuffer()

char* getbuffer()

static char dd[100]="abcdefg";

char * buf=dd;

return buf;

}如果有個函式會對getbuffer()的dd陣列進行連線操作,加入第一次在「abcdefg」後面連線上「hlk」,

當第一呼叫getbuffer時,陣列達dd發生了改變,變長了。等第二次呼叫getbuffer時,並對dd陣列繼續進行連線加長時,第二次再呼叫getbuffer時就可以在「abcdefghlk」的基礎上連線。如果沒有生命陣列dd是static的,第二次呼叫時只能在「abcdefg」的基礎上連線。

迴圈內部區域性變數與呼叫棧

正如其他部落格所提到的,區域性變數的生命週期是在乙個大括號內,即乙個所處塊結束。區域性變數和全域性變數的區別,區域性變數的生命週期是從建立開始到所處的塊結束就被 而全域性變數的生命週期是從建立開始到程式結束。正如上面所說,區域性變數是直到所處的塊結束才從呼叫棧中把它 先看下面的 for int i ...

方法內部多執行緒呼叫區域性變數問題

問題場景 方法內部多執行緒呼叫內部區域性變數集合,併發寫入資料庫,集合執行緒間隔離 執行緒呼叫完畢就需要清空集合 資料不重複寫入問題 核心 片段 class threadsync implements runnable override public void run esrestclient.ge...

函式區域性變數的返回

昨天看到一道程式設計糾錯題,在網上看到乙個講解非常詳細的文章,這裡拿來和大家分享一下 一般的來說,函式是可以返回區域性變數的。區域性變數的作用域只在函式內部,在函式返回後,區域性變數的記憶體已經釋放了。因此,如果函式返回的是區域性變數的值,不涉及位址,程式不會出錯。但是如果返回的是區域性變數的位址 ...