C 11의 Vector::resize() 및 Boost.Container가 예상대로 작동합니까?
C 03에서 std:: 벡터::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으로 초기화되는 것으로 관찰되었습니다. 값 초기화.
예상 동작 이해:
값 초기화 복사 초기화는 새 요소가 제공된 값의 복사본으로 초기화되어야 함을 의미하는 반면, 복사 초기화는 새 요소가 기본값(예: 정수의 경우 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 모드의 출력은 예상한 대로입니다. std_vec 및 Boost_vec의 새 요소는 0으로 초기화되는 반면 Boost_vec_default의 요소는 기본적으로 초기화됩니다.
C 11 모드에서 컴파일:
그러나 C의 출력은 11 모드에서는 std_vec 및 Boost_vec의 새 요소가 여전히 0으로 초기화되고 있음을 보여줍니다. 이는 resize(size_type n)의 예상 동작이 충족되지 않음을 나타냅니다.
설명:
이 예상치 못한 동작의 이유는 컴파일러가 최적화 중일 수 있기 때문입니다. resize()의 값 초기화 오버로드 호출을 종료합니다. 값 초기화를 강제하려면 constructor() 메서드를 재정의하여 명시적으로 값 초기화를 수행하는 할당자를 사용할 수 있습니다.
위 내용은 C 11의 `std::Vector::resize()`와 Boost.Container의 `boost::container::Vector::resize()`는 항상 예상대로 값 초기화를 수행합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!