首頁 >後端開發 >C++ >new 運算子何時將記憶體初始化為零?

new 運算子何時將記憶體初始化為零?

DDD
DDD原創
2024-12-19 00:56:18432瀏覽

When Does the `new` Operator Initialize Memory to Zero?

New 運算子和記憶體初始化

眾所周知,new 運算子會在不初始化記憶體的情況下分配記憶體。然而,最近的程式碼範例揭示了一種情況,即在使用 new 分配時記憶體似乎被初始化為零。這引發了有關運算子實際行為的問題。

程式碼:

#include <iostream>

int main() {
  unsigned int *wsk2 = new unsigned int(5);
  std::cout << "wsk2: " << wsk2 << " " << *wsk2 << std::endl;
  delete wsk2;
  wsk2 = new unsigned int;
  std::cout << "wsk2: " << wsk2 << " " << *wsk2 << std::endl;
  return 0;
}

輸出:

wsk2: 0x928e008 5
wsk2: 0x928e008 0

wsk2 的第一次分配和初始化到值5 按預期運作。然而,第二次指派 wsk2 並將其賦值給一個沒有初始化器的新的 unsigned int 會導致值為 0。

經過進一步調查,很明顯new 運算子有兩個版本:

  • wsk = 新的無符號整數; // 預設初始化(即什麼也沒發生)
  • wsk = new unsigned int(); // 零初始化(即設定為0)

此行為也適用於陣列:

  • wsa = new unsigned int[5]; // 預設初始化(即什麼也沒發生)
  • wsa = new unsigned int[5](); // 零初始化(即所有元素設定為0)

使用placement new 的自訂測試確認零初始化確實發生:

#include <new>
#include <iostream>

int main() {
  unsigned int wsa[5] = {1, 2, 3, 4, 5};
  unsigned int *wsp = new(wsa) unsigned int[5]();
  std::cout << wsa[0] << "\n"; // If these are zero then it worked as described.
  std::cout << wsa[1] << "\n"; // If they contain the numbers 1 - 5 then it failed.
  std::cout << wsa[2] << "\n";
  std::cout << wsa[3] << "\n";
  std::cout << wsa[4] << "\n";
}

輸出:

0
0
0
0
0

這表示new 運算子在與括號一起使用時支援零初始化,儘管人們普遍誤解它會留下記憶體未初始化。

以上是new 運算子何時將記憶體初始化為零?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn