3.普通函数与函数模板的调用规则

一.规则总述:

-如果函数模板和普通函数都可以实现,优先调用普通函数

-可以通过空模板参数列表来强制调用函数模板

-函数模板也可以发生重载

-如果函数模板可以产生更好的匹配,优先调用函数模板

(1).如果函数模板和普通函数都可以实现,优先调用普通函数

cpp 复制代码
#include<iostream>
using namespace std;

//普通函数
void Print(int a, int b)
{
    cout << "调用的普通函数" << endl;
}

//函数模板
template <class T>
void Print(T a, T b)
{
    cout << "调用的模板" << endl;
}

void test()
{
    int a = 10, b = 20;
    //如果函数模板和普通函数都可以实现,优先调用普通函数
    Print(a, b);
}

int main()
{
    test();
    return 0;
}

运行结果

cpp 复制代码
调用的普通函数

(2)可以通过空模板参数列表来强制调用函数模板

cpp 复制代码
#include<iostream>
using namespace std;


void Print(int a, int b)
{
    cout << "调用的普通函数" << endl;
}


template <class T>
void Print(T a, T b)
{
    cout << "调用的模板" << endl;
}

void test()
{
    int a = 10, b = 20;
    //通过空模板参数列表,强制调用函数模板
    Print<>(a, b);
}

int main()
{
    test();
    return 0;
}

运行结果

cpp 复制代码
调用的模板

(3)函数模板也可以发生重载

cpp 复制代码
#include<iostream>
using namespace std;


void Print(int a, int b)
{
    cout << "调用的普通函数" << endl;
}


template <class T>
void Print(T a, T b)
{
    cout << "调用的模板" << endl;
}

template <class T>
void Print(T a, T b, T c)
{
    cout << "调用重载的模板" << endl;
}

void test()
{
    int a = 10, b = 20, c = 30;
    //函数模板也可以发生重载
    Print(a, b, c);
    Print<>(a, b, c);
}

int main()
{
    test();
    return 0;
}

运行结果

cpp 复制代码
调用重载的模板
调用重载的模板

(4)如果函数模板可以产生更好的匹配,优先调用函数模板

cpp 复制代码
#include<iostream>
using namespace std;


void Print(int a, int b)
{
    cout << "调用的普通函数" << endl;
}


template <class T>
void Print(T a, T b)
{
    cout << "调用的模板" << endl;
}

template <class T>
void Print(T a, T b, T c)
{
    cout << "调用重载的模板" << endl;
}

void test()
{
    char a = 'a';
    char b = 'b';
    
    //如果函数模板可以产生更好的匹配,优先调用函数模板
    Print(a, b);
}

int main()
{
    test();
    return 0;
}

运行结果

cpp 复制代码
调用的模板

解释:在这里,变量为字符型,普通函数传入字符型变量可以发生隐式转换,模板函数可以自动匹配参数类型但是,普通函数要发生类型转换,模板函数不需要,显然模板函数的调用要更适合,因此在这里的结果是调用了模板函数

二.总结:

既然提供了函数模板,最好就不要提供普通函数,否则容易出现二义性

相关推荐
hanbr4 小时前
C++ 初涉
开发语言·c++
Дерек的学习记录4 小时前
C++:入门基础(下)
开发语言·数据结构·c++·学习·算法·visualstudio
yugi9878385 小时前
无线传感器网络中GAF算法节点特性分析
网络·算法
云小逸5 小时前
【nmap源码解析】Nmap 核心技术深度解析:从源码到实战
开发语言·网络·windows·nmap
1027lonikitave5 小时前
使用斐波那契数列讲解尾递归
算法
前路不黑暗@5 小时前
Java项目:Java脚手架项目的公共模块的实现(二)
java·开发语言·spring boot·学习·spring cloud·maven·idea
人道领域5 小时前
Spring核心注解全解析
java·开发语言·spring boot
云深麋鹿6 小时前
标准库中的String类
开发语言·c++·容器
滴滴答滴答答6 小时前
LeetCode Hot100 之 16 合并两个有序链表
算法·leetcode·链表
脱离语言6 小时前
Jeecg3.8.2 前端经验汇总
开发语言·前端·javascript