>백엔드 개발 >C++ >C++ 11 및 C++ 14의 STL 함수 개체가 개선되었나요?

C++ 11 및 C++ 14의 STL 함수 개체가 개선되었나요?

王林
王林원래의
2024-04-25 22:06:01442검색

STL 함수 개체는 C++11의 완벽한 전달 및 이동 의미 체계, C++14의 함수 포인터 캡슐화 및 일반 람다를 포함하여 크게 개선되었습니다. 이러한 개선 사항은 유용성, 효율성 및 유연성을 향상시킵니다. 예를 들어 일반 람다는 단순히 std::less{}를 사용하여 내림차순으로 정렬함으로써 정렬 함수 객체 작성을 단순화합니다.

C++ 11 和 C++ 14 中 STL 函数对象的改进?

C++ 11 및 C++ 14의 STL 함수 개체 개선

C++ 표준 라이브러리(STL)가 발전하는 동안 함수 개체가 크게 개선되었습니다. 이러한 개선 사항은 유용성, 효율성 및 유연성을 향상시키기 위해 설계되었습니다.

C++ 11의 개선 사항

  • 완벽한 전달: 완벽한 전달을 사용하면 함수 개체가 명시적인 유형 변환이나 복사 없이 함수 인수를 수신 및 전달할 수 있어 효율성이 향상됩니다.

코드 예:

struct Forwarder {
  template <typename ...Args>
  void operator()(Args&&... args) const {
    std::forward<Args>(args)...; // 完美转发参数
  }
};
  • 이동 의미론: 이동 의미론을 사용하면 함수 객체가 복사하는 대신 내부 상태를 이동할 수 있어 효율성이 더욱 향상됩니다.

코드 예:

struct Mover {
  std::string value;

  Mover(Mover&& other) noexcept
    : value(std::move(other.value)) {
    other.value.clear(); // 移出旧值
  }
};

C++ 14의 개선 사항

  • 함수 포인터 캡슐화: C++ 14에서는 함수 포인터를 캡슐화할 수 있는 std::function 유형을 도입하여 함수 포인터를 더 쉽게 캡슐화할 수 있습니다. 객체로 사용됩니다.

코드 예:

auto plus = std::function<int(int, int)>([](int a, int b) { return a + b; });
  • 일반 람다: 일반 람다를 사용하면 템플릿을 사용하여 람다 식 유형을 지정할 수 있으므로 유형 안전성과 유연성이 제공됩니다.

코드 예:

auto sort_by = [](const auto& a, const auto& b) { return a < b; };

실용 사례

학생 성적의 데이터 구조가 있다고 가정하고 이제 STL 함수 개체를 사용하여 성적을 정렬하려고 합니다.

C++ 11 코드:

std::vector<int> grades = {90, 85, 95, 88, 92};

std::sort(grades.begin(), grades.end(),
  [](int a, int b) { return a > b; }); // 降序排序

C++ 14 코드:

std::vector<int> grades = {90, 85, 95, 88, 92};

std::ranges::sort(grades, std::less{}); // 降序排序

보시다시피 C++ 14에 도입된 일반 람다는 정렬된 함수 개체 작성을 단순화합니다.

위 내용은 C++ 11 및 C++ 14의 STL 함수 개체가 개선되었나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.