[問題] 為什麼static 的變數不會被初始化

看板C_and_CPP (C/C++)作者 (薯)時間1周前 (2025/03/25 22:11), 1周前編輯推噓5(5015)
留言20則, 6人參與, 6天前最新討論串1/1
想問個小問題 在某一個版本之後 關於singleton的寫法推薦如下 QByteArray& AlbumItem::placeholderBytes(){ static QByteArray bytes; if (bytes.isNull()){ //.................... } } return bytes; } 後來我想改用指標 QByteArray* AlbumItem::placeholderBytes(){ static QByteArray *bytes = nullptr; if (bytes == nullptr){ //........................ } } return bytes; } 本來我擔心已經存在記憶體裡的*bytes會被初始化為nullptr 造成非singleton的情況 並且導致有記憶體洩漏 還好測試一下並沒有這樣的情況發生 想請問是否是因為他檢查如果該static 變數已存在於記憶體 就會跳過宣告這行程式碼嗎? 還是說實際上有其他動作,只是剛好結果符合我想要的呢? -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 123.194.20.237 (臺灣) ※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1742911880.A.516.html ※ 編輯: liu2007 (123.194.20.237 臺灣), 03/25/2025 22:11:47

03/25 22:21, 1周前 , 1F
static variable 只會在第一次跑到的時候執行一次
03/25 22:21, 1F

03/25 22:21, 1周前 , 2F

03/25 22:21, 1周前 , 3F
_duration#Static_block_variables
03/25 22:21, 3F

03/25 22:22, 1周前 , 4F
樓下支援C++標準文件
03/25 22:22, 4F

03/26 08:52, 1周前 , 5F

03/26 08:52, 1周前 , 6F
n-c-8e20e6c3c96d
03/26 08:52, 6F

03/26 09:03, 1周前 , 7F
發現中文的了,該講的差不多都有講到XD
03/26 09:03, 7F

03/26 09:03, 1周前 , 8F

03/26 10:07, 1周前 , 9F
function本地的static要能保留沿用,要每次初始化那static
03/26 10:07, 9F

03/26 10:07, 1周前 , 10F
就沒意義了吧,反之我以為就是用static的目的
03/26 10:07, 10F

03/26 16:01, 1周前 , 11F
c++ runtime 有一部份在處理 local static object
03/26 16:01, 11F

03/26 16:01, 1周前 , 12F
讓 static object 只初始化一次
03/26 16:01, 12F

03/26 16:01, 1周前 , 13F
大概是要讓 object 的行為和 c static 變數有一樣的行為
03/26 16:01, 13F

03/26 19:00, 1周前 , 14F
會sync但可以用-fno-threadsafe-statics關掉,然後
03/26 19:00, 14F

03/26 19:00, 1周前 , 15F
Itanium C++ ABI有規定api讓compiler生code來呼叫runti
03/26 19:00, 15F

03/26 19:00, 1周前 , 16F
me來達成這件事
03/26 19:00, 16F

03/27 00:49, 6天前 , 17F
不能理解你的問題,初始化完他就是nullptr, 然後qt有sma
03/27 00:49, 17F

03/27 00:49, 6天前 , 18F
rt pointer所以本來就不會leak吧
03/27 00:49, 18F

03/27 00:50, 6天前 , 19F
問題是你改成static ptr誰要負責幫你new?沒有data race?
03/27 00:50, 19F

03/27 00:51, 6天前 , 20F
你的if 裡面要做什麼,這個function要做什麼描述一下
03/27 00:51, 20F
文章代碼(AID): #1duhc8KM (C_and_CPP)
文章代碼(AID): #1duhc8KM (C_and_CPP)