C 11의 `std::make_pair`에서 템플릿 매개변수를 명시적으로 지정하면 컴파일에 실패하는 이유는 무엇입니까?
지정된 템플릿 매개변수가 있는 C 11 make_pair가 컴파일되지 않습니다
Q:
g 4.7과 함께 C 11을 사용하는 동안, 명시적으로 지정된 템플릿 매개변수와 함께 std::make_pair 함수를 사용하여 코드를 컴파일하려는 시도가 실패합니다. 이 오류의 원인을 이해하는 것이 목표입니다.
A:
make_pair에 대한 잘못된 사용법
std::make_pair 자동 템플릿 인수 추론을 위한 것입니다. 템플릿 매개변수를 명시적으로 지정하면 이러한 추론이 방지되어 실제 인수 유형과 예상 인수 유형이 일치하지 않게 됩니다. 함수는 T&& 및 U&& 유형의 인수를 사용합니다. 여기서 T와 U는 템플릿 유형 매개변수이며 다음과 유사합니다.
template<typename T, typename U> make_pair(T&& argT, U&& argU);
인수 유형 불일치
템플릿 매개변수를 지정할 때 명시적으로는 인수 추론이 발생하지 않습니다. 대신 지정된 유형이 함수 템플릿에서 직접 사용되어 다음과 같은 결과가 발생합니다.
make_pair(std::string&& argT, int&& argU);
이 경우 두 매개 변수 유형 모두 rvalue 참조이며 rvalue에만 바인딩할 수 있습니다. 그러나 인수 중 하나인 s는 lvalue(기존 객체)이므로 예상되는 rvalue 참조 유형과 호환되지 않습니다. 따라서 함수 템플릿이 제공된 인수와 일치할 수 없어 컴파일 오류가 발생합니다.
make_pair의 올바른 사용법
이 문제를 해결하려면 명시적인 템플릿 매개변수 사양을 제거하세요. 자동 인수 추론을 허용합니다. 이 시나리오에서 컴파일러는 T를 std::string으로 추론할 수 있습니다. s는 std::string 유형의 lvalue이므로 최종 인수 유형으로 std::string&이 됩니다. 마찬가지로 U는 int로 추론되며 인수 7은 int 유형의 rvalue이므로 int&&가 됩니다. 이러한 인수 유형은 함수 템플릿과 정확하게 일치하므로 성공적인 컴파일이 가능합니다.
템플릿에 대한 일반 지침
템플릿의 경우 일반적으로 컴파일러가 템플릿 인수 추론을 수행하도록 하는 것이 좋습니다. 가능할 때마다. 템플릿 매개변수를 명시적으로 지정하는 것은 꼭 필요한 경우에만 수행해야 합니다.
위 내용은 C 11의 `std::make_pair`에서 템플릿 매개변수를 명시적으로 지정하면 컴파일에 실패하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











C 언어 데이터 구조 : 트리 및 그래프의 데이터 표현은 노드로 구성된 계층 적 데이터 구조입니다. 각 노드에는 데이터 요소와 하위 노드에 대한 포인터가 포함되어 있습니다. 이진 트리는 특별한 유형의 트리입니다. 각 노드에는 최대 두 개의 자식 노드가 있습니다. 데이터는 structtreenode {intdata; structtreenode*왼쪽; structReenode*오른쪽;}을 나타냅니다. 작업은 트리 트래버스 트리 (사전 조정, 인 순서 및 나중에 순서) 검색 트리 삽입 노드 삭제 노드 그래프는 요소가 정점 인 데이터 구조 모음이며 이웃을 나타내는 오른쪽 또는 무의미한 데이터로 모서리를 통해 연결할 수 있습니다.

이 기사에서는 컨테이너, 반복자, 알고리즘 및 함수 인 핵심 구성 요소에 중점을 둔 C 표준 템플릿 라이브러리 (STL)에 대해 설명합니다. 일반적인 프로그래밍을 가능하게하기 위해 이러한 상호 작용, 코드 효율성 및 가독성 개선 방법에 대해 자세히 설명합니다.

이 기사는 효율적인 STL 알고리즘 사용을 자세히 설명합니다. 데이터 구조 선택 (벡터 대 목록), 알고리즘 복잡성 분석 (예 : std :: sort vs. std :: partial_sort), 반복자 사용 및 병렬 실행을 강조합니다. 일반적인 함정과 같은

이 기사는 C에서 효과적인 예외 처리를 자세히 설명하고, 시도, 캐치 및 던지기 메커니즘을 다룹니다. RAII와 같은 모범 사례, 불필요한 캐치 블록을 피하고 강력한 코드에 대한 예외를 기록합니다. 이 기사는 또한 Perf를 다룹니다

기사는 Move Semantics, Perfect Forwarding 및 Resource Management에 대한 C에서 RValue 참조의 효과적인 사용에 대해 논의하여 모범 사례 및 성능 향상을 강조합니다 (159 자).

파일 작동 문제에 대한 진실 : 파일 개방이 실패 : 불충분 한 권한, 잘못된 경로 및 파일이 점유 된 파일. 데이터 쓰기 실패 : 버퍼가 가득 차고 파일을 쓸 수 없으며 디스크 공간이 불충분합니다. 기타 FAQ : 파일이 느리게 이동, 잘못된 텍스트 파일 인코딩 및 이진 파일 읽기 오류.

C 20 범위는 표현성, 합성 가능성 및 효율성으로 데이터 조작을 향상시킵니다. 더 나은 성능과 유지 관리를 위해 복잡한 변환을 단순화하고 기존 코드베이스에 통합합니다.

이 기사는 C의 동적 파견, 성능 비용 및 최적화 전략에 대해 설명합니다. 동적 파견이 성능에 영향을 미치는 시나리오를 강조하고이를 정적 파견과 비교하여 성능과 성능 간의 트레이드 오프를 강조합니다.
