C 11 Rvalue 참조 및 이동 의미 체계: 반환 값 풀기
C 11 영역에서는 rvalue 참조 및 이동 의미 체계를 이해하는 것이 중요합니다. . 이 글의 목적은 세 가지 코드 예제 간의 차이점을 명확히 하고 벡터 중복을 방지하는 코드를 결정하는 것입니다.
첫 번째 예제
std::vector<int> return_vector(void) { std::vector<int> tmp {1,2,3,4,5}; return tmp; } std::vector<int> &&rval_ref = return_vector();
여기서 함수는 지역 변수를 반환합니다. tmp, 값별. 참조 rval_ref는 tmp의 복사본에 바인딩됩니다. 이는 다음과 유사합니다:
const std::vector<int> &rval_ref = return_vector();
rval_ref를 const가 아닌 작업에 사용할 수 없다는 점만 제외하면
두 번째 예
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();
이것은 예제에서는 이동된 지역 변수 tmp를 반환하려고 잘못 시도합니다. 함수가 종료되면 tmp가 파괴되므로 rval_ref는 매달린 참조를 보유합니다. 이로 인해 런타임 오류가 발생할 가능성이 높습니다.
세 번째 예
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();
이 예는 tmp가 값으로 반환되는 첫 번째 예와 유사합니다. 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();
지역 변수 tmp는 return 문에서 암시적으로 rvalue로 처리됩니다. 컴파일러는 RVO를 적용하여 복사나 이동을 피하거나 필요한 경우 이동 생성자를 사용합니다.
위 내용은 C 11 Rvalue 참조 및 이동 의미 체계가 벡터 반환 값을 어떻게 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!