STL 알고리즘과 함께 로컬로 정의된 클래스 사용
프로그래밍에서는 로컬로 정의된 클래스를 STL 알고리즘의 조건자로 사용하는 것이 바람직한 경우가 많습니다. 안타깝게도 C 98/03 표준에서는 다음과 같이 명시적으로 이러한 관행을 금지합니다.
A local type, a type with no linkage, an unnamed type or a type compounded from any of these types shall not be used as a template-argument for a template type-parameter.
이 제한 사항은 C 표준의 14.3.1조에 명시되어 있습니다.
처음에는 이 제한 사항이 많은 프로그래머는 실수로 간주하고 표준이 더 빨리 발전했다면 더 빨리 수정되었을 것입니다. 그러나 C 11에서는 이러한 제한이 제거되어 로컬 유형을 템플릿 인수로 사용할 수 있습니다.
예를 들어 이전에 C 98/03에서 유효하지 않았던 다음 코드는 이제 C 11에서 허용됩니다.
int main() { int array[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; std::vector<int> v( array, array+10 ); struct even : public std::unary_function<int,bool> { bool operator()( int x ) { return !( x % 2 ); } }; std::remove_if( v.begin(), v.end(), even() ); }
대부분의 최신 컴파일러에서는 람다 표현식 지원과 함께 로컬 클래스를 템플릿 인수로 사용할 수 있습니다.
위 내용은 STL 알고리즘에서 로컬 클래스를 템플릿 인수로 사용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!