C++17의 새로운 기능은 무엇입니까?

青灯夜游
풀어 주다: 2022-12-30 11:13:03
원래의
12812명이 탐색했습니다.

c++17의 새로운 기능은 다음과 같습니다. 1. 자동 표현식 파생 규칙 변경 2. 람다 표현식은 "*this"를 캡처할 수 있습니다. 3. 새로운 인라인 변수, 전역 변수를 헤더 파일에서 직접 정의할 수 있습니다. 4. 조건식에서 초기화 문을 지원합니다. 5. 열거형의 직접 목록 초기화.

C++17의 새로운 기능은 무엇입니까?

이 튜토리얼의 운영 환경: Windows 7 시스템, C++17 버전, Dell G3 컴퓨터.

관련 추천: "C++ 동영상 튜토리얼"

C++17의 새로운 기능

1. auto 키워드

c++11부터 auto 키워드를 초기화할 수 있습니다. 변수의 유형을 추론합니다. C++14에서는 auto 키워드의 능력이 더욱 향상되었으며, return 문을 통해 함수의 반환 타입을 유추할 수 있다. auto 키워드를 사용하면 코딩 효율성이 향상되고 재구성 프로세스가 단순화될 수 있습니다. 그러나 C++11의 자동 파생 결과는 예상과 다른 경우가 많습니다.

통합 초기화를 지원하기 위해 아래와 같이 새로운 통합 초기화 구문이 C++11에 도입되었습니다.

// c++11
auto x3{ 1, 2 }; // std::initializer_list<int>
auto x4 = { 3 }; // decltype(x4) is std::initializer_list<int>
auto x5{ 3 };    // std::initializer_list<int>
로그인 후 복사

이 세 가지 방법으로 초기화된 변수의 경우 최종 유형 파생 결과는 우리가 생각하는 int가 아닌 std::initializer_list입니다. 이는 변수 auto를 선언하는 데 사용되는 표현식이 {}로 묶이면 추론된 유형이 std::initializer_list가 되기 때문입니다.

C++17에서는 자동 표현식 파생 규칙이 변경되었습니다

// c++17
auto x3{ 1, 2 }; // error: not a single element
auto x4 = { 3 }; // decltype(x4) is std::initializer_list<int>
auto x5{ 3 };    // decltype(x5) is int
로그인 후 복사

비교 결과 auto x5{3}가 변수를 x5로 직접 파생시키고 x3{1, 2}도 컴파일이 실패하는 것으로 나타났습니다. 자동 파생 규칙이 더욱 직관적이 되었습니다.

2. 람다 표현식

lambda는 C++11에도 도입되었습니다. C++11에서는 람다 표현식이 현재 개체에 대한 읽기 전용 참조만 캡처할 수 있습니다. C++17에서는 *이것은 현재 개체의 복사본입니다. 현재 개체의 복사본을 캡처하면 현재 개체가 해제된 후 람다 식에서 변수와 메서드를 안전하게 호출할 수 있습니다. 이것.

3. 인라인 변수

인라인 변수, 인라인 변수를 사용하면 변수를 두 번 이상 정의할 수 있습니다. C++17 이전에는 전역 변수를 정의할 때 항상 cpp 파일에서 변수를 정의한 다음 extern 키워드를 사용하여 변수가 다른 곳에 정의되었음을 컴파일러에 알려야 했습니다. 인라인 변수가 나타난 후에는 재정의 오류 메시지에 대한 걱정 없이 헤더 파일에서 전역 변수를 직접 정의할 수 있습니다.

4. 조건식에서 초기화 문이 지원됩니다.

C++17에서는 if 또는 switch 문에서 초기화를 지원하므로 코드가 더욱 간결해집니다.

// c++17之前
map<int, string> c = {{1,"a"}};
{
    auto res = c.insert(make_pair(2, "b"));
    if(!res.second) {
        cout << "key 1 exist" << endl;
    } else {
        cout << "insert success, value:" << res.first->second << endl;
    }
}
로그인 후 복사

위 코드에서 res는 임시 변수이고 후속 코드에 영향을 주지 않기 때문에 중괄호 쌍을 사용하여 범위를 제한합니다. 하지만 c++17의 구문을 사용하고 if 조건에서 res를 초기화하면 코드가 더 간결해집니다

// c++17
map<int, string> c = {{1,"a"}};
if(auto res = c.insert(make_pair(2, "b")); !res.second ) {
    cout << "key 1 exist" << endl;
} else {
    cout << "insert success, value:" << res.first->second << endl;
}
로그인 후 복사

c++17의 표준 라이브러리도 확장되었으며 다음과 같은 데이터 유형이 추가되었습니다.

1.std::variant

std::variant는 유형이 안전한 Union이며 향상된 버전의 Union입니다.

2. :: 선택사항

std::선택사항은 가능한 값을 나타냅니다. 우리는 함수를 통해 객체를 생성할 때 보통 함수를 사용하여 오류 코드를 반환하고, 매개변수를 통해 객체 자체를 반환합니다. 생성된 인스턴스를 Optional을 통해 반환하면 더욱 직관적이 됩니다.

has_value()   // 检查对象是否有值
value()       // 返回对象的值,值不存在时则抛出 std::bad_optional_access 异常
value_or()    // 值存在时返回值,不存在时返回默认值
로그인 후 복사

3. std::any

모든 값을 저장할 수 있는 형식이 안전한 컨테이너입니다.

4. std::string_view

string_view 처음에는 Boost 버전을 사용했는데, C++17의 string_view는 Boost와 비슷합니다. string_view는 원래 문자열에 대한 읽기 전용 참조로 이해될 수 있습니다. string_view 자체는 원본 문자열 데이터를 저장하기 위해 추가 메모리를 적용하지 않고 원본 문자열 주소와 길이만 저장합니다. 대부분의 경우 문자열을 일시적으로만 처리하므로 원본 문자열의 복사본이 필요하지 않습니다. string_view를 사용하면 불필요한 메모리 복사본을 줄이고 프로그램 성능을 향상시킬 수 있습니다. 문자열 포인터를 사용하는 것과 비교하여 string_view는 더 나은 캡슐화를 제공합니다.

string_view에는 원본 문자열의 소유권이 없다는 점에 유의해야 합니다. string_view를 사용할 때는 원본 문자열의 수명 주기에 주의해야 합니다. 원래 문자열이 삭제되면 string_view를 더 이상 호출할 수 없습니다.

기타 기능:

또한 C++17에는 기사에 하나씩 나열되지 않은 몇 가지 다른 기능도 추가됩니다.

    bool 표현식은 ++를 사용할 수 없습니다. - 이 두 가지 증가(뺄셈) 연산자
  • c++17의 예외는 유형 시스템의 일부가 되었습니다.
  • 열거형은 직접 목록 초기화입니다
  • 구조적 바인딩
  • constexpr if 표현식
  • map은 병합 및 추출을 지원합니다

더 많은 프로그래밍 관련 지식을 보려면 프로그래밍 배우기를 방문하세요! !

위 내용은 C++17의 새로운 기능은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!