C 11 和 Boost.Container 中的 Vector::resize() 是否如預期運作?
在 C 03 中,std:: vector::resize() 函式只有一個重載,可以用特定值初始化新元素。 C 11 引入了兩個重載:用於值初始化的 resize(size_type n) 和用於複製初始化的 resize(size_type n, const value_type &val)。
Boost.Container 的 boost::container::vector 也支援值初始化在其 resize() 方法中。然而,在測試了 C 11 的 std::vector 和 Boost.Container 的 boost::container::vector 的行為後,我們發現添加到向量中的最終元素仍然用零初始化,儘管其目的是使用值初始化。
理解預期行為:
值初始化意味著新元素應該使用預設值初始化(例如,整數為0),而複製初始化意味著新元素應使用提供值的副本進行初始化。
測試結果:
使用以下程式碼來測試行為:
int main() { // Initialize vectors std::vector<int> std_vec; bc::vector<int> boost_vec; bc::vector<int> boost_vec_default; // Fill and resize vectors init_vec(std_vec); init_vec(boost_vec); init_vec(boost_vec_default); // Resize vectors to 10 elements using different techniques std_vec.resize(10); boost_vec.resize(10); boost_vec_default.resize(10, bc::default_init); // Print results print_vec("std", std_vec); print_vec("boost", boost_vec); print_vec("boost w/default", boost_vec_default); }
在C 03 中編譯模式:
在C 03 中編譯模式:
C 03 模式下的輸出符合預期。 std_vec 和 boost_vec 中的新元素以零初始化,而 boost_vec_default 中的元素則預設初始化。
在 C 11 模式下編譯:
但是,C 中的輸出11 模式顯示 std_vec 和 boost_vec 中的新元素仍在用零初始化。這表示未滿足 resize(size_type n) 的預期行為。
說明:
出現此意外行為的原因是編譯器可能正在最佳化輸出對 resize() 的值初始化重載的呼叫。為了強制值初始化,可以使用一個分配器來重寫construct()方法來明確地執行值初始化。以上是C 11 的 `std::vector::resize()` 和 Boost.Container 的 `boost::container::vector::resize()` 是否總是按預期進行值初始化?的詳細內容。更多資訊請關注PHP中文網其他相關文章!