rvalue 참조 및 이동 의미 이해
C 11에서 rvalue 임시 값으로 작업할 때 성능과 효율성을 향상시키기 위해 참조 및 이동 의미 체계가 도입되었습니다. rvalue 참조(&&)는 임시 개체를 참조하는 반면, 이동 의미 체계를 사용하면 복사하지 않고도 한 개체의 내용을 다른 개체로 이동할 수 있습니다.
예 1
std::vector<int> return_vector(void) { std::vector<int> tmp {1,2,3,4,5}; return tmp; } std::vector<int> &&rval_ref = return_vector();
이 예에서 return_Vector 함수는 rvalue 참조 rval_ref에 의해 포착되는 임시 std::벡터 개체를 반환합니다. 임시 개체가 rval_ref로 이동되므로 복사가 효과적으로 방지됩니다.
예 2
std::vector<int>&& return_vector(void) { std::vector<int> tmp {1,2,3,4,5}; return std::move(tmp); } std::vector<int> &&rval_ref = return_vector();
이 경우 return_Vector 함수는 임시 std를 반환합니다. :Vector 객체를 값으로 지정하고 std::move 함수를 사용하여 임시 객체의 내용을 반환된 객체로 명시적으로 이동합니다. 이제 rval_ref가 파괴된 임시 객체에 대한 참조를 보유하고 있으므로 런타임 오류가 발생합니다.
예제 3
std::vector<int> return_vector(void) { std::vector<int> tmp {1,2,3,4,5}; return std::move(tmp); } std::vector<int> &&rval_ref = return_vector();
이 예는 예 1과 유사합니다. return_Vector 함수는 임시 std::벡터 객체를 값으로 반환하고 std::move를 사용하여 내용을 이동합니다. 그러나 이 경우 std::move는 불필요하며 반환 값 최적화를 방해하여 성능을 저하시킬 수 있습니다.
모범 사례
가장 좋은 접근 방식은 예제를 사용하는 것입니다. 4, 여기서 임시 개체는 명시적으로 std::move를 사용하지 않고 반환된 개체로 암시적으로 이동됩니다. 컴파일러는 불필요한 복사를 피하기 위해 반환 값 최적화(RVO)를 수행합니다.
std::vector<int> return_vector(void) { std::vector<int> tmp {1,2,3,4,5}; return tmp; } std::vector<int> rval_ref = return_vector();
위 내용은 C 11 Rvalue 참조 및 이동 의미 체계가 반환 문에 어떤 영향을 미칩니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!