일반 프로그래밍은 템플릿과 가상 함수를 통해 C++로 구현됩니다. 함수 오버로딩은 템플릿을 사용하여 모든 유형을 허용합니다. 함수 재정의는 가상 템플릿 함수를 사용하여 파생 클래스의 자체 구현을 제공합니다. 실제적인 예로는 일반 함수 오버로딩을 사용하여 요소를 찾는 것과 일반 함수를 사용하여 인쇄 컨테이너 요소를 재정의하는 것이 있습니다.
일반 프로그래밍은 데이터 유형에 독립적인 코드를 작성하여 코드를 단순화하고 재사용하는 것을 말합니다. C++에서는 템플릿과 가상 함수를 사용하여 일반 프로그래밍을 구현할 수 있습니다.
함수 오버로드를 사용하면 동일한 이름을 사용하여 다양한 매개변수 유형으로 여러 함수를 만들 수 있습니다. 템플릿을 사용하면 함수 오버로드가 모든 유형의 인수를 허용하도록 할 수 있습니다.
template <typename T> void swap(T& a, T& b) { T temp = a; a = b; b = temp; }
함수 재정의를 사용하면 파생 클래스가 부모 클래스의 가상 함수에 대한 자체 구현을 제공할 수 있습니다. 가상 템플릿 함수를 사용하면 일반 재작성을 달성할 수 있습니다.
class Base { public: virtual void print() { std::cout << "Base class" << std::endl; } }; class Derived : public Base { public: virtual void print() override { std::cout << "Derived class" << std::endl; } };
실용 사례
일반 함수 오버로드를 사용하여 요소 찾기
template <typename T> bool find(std::vector<T>& vec, T value) { for (const auto& element : vec) { if (element == value) { return true; } } return false; } int main() { std::vector<int> int_vec = {1, 2, 3}; std::cout << std::boolalpha << find(int_vec, 2) << std::endl; // true std::vector<std::string> str_vec = {"Hello", "World"}; std::cout << std::boolalpha << find(str_vec, "World") << std::endl; // true }
일반 함수를 사용하여 인쇄 컨테이너 요소 재작성
template <typename T> void print_container(std::vector<T>& vec) { for (const auto& element : vec) { std::cout << element << " "; } std::cout << std::endl; } int main() { std::vector<int> int_vec = {1, 2, 3}; print_container(int_vec); // 输出: 1 2 3 std::vector<std::string> str_vec = {"Hello", "World"}; print_container(str_vec); // 输出: Hello World }
위 내용은 C++ 함수 오버로딩 및 재작성에 일반 프로그래밍 적용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!