首頁 >後端開發 >C++ >C 11 的 `std::vector::resize()` 和 Boost.Container 的 `boost::container::vector::resize()` 是否總是按預期進行值初始化?

C 11 的 `std::vector::resize()` 和 Boost.Container 的 `boost::container::vector::resize()` 是否總是按預期進行值初始化?

DDD
DDD原創
2024-12-09 08:07:06689瀏覽

Does C  11's `std::vector::resize()` and Boost.Container's `boost::container::vector::resize()` Always Value-Initialize as Expected?

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中文網其他相關文章!

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