在两个cpp文件中都有一个相同的模板定义,并且都有相同实例,那么在main文件中调用这个实例会调用哪个模板实例呢?
//文件名caller1.cpp
#include<iostream>
template<typename T>
void func(T const &v)
{
std::cout<<"func1: "<<v<<std::endl;
}
void caller1()
{
func(1);
func(0.1);
}
//文件名caller2.cpp
#include<iostream>
template<typename>
void func(T const &v)
{
std::cout<<"func2: "<<v<<std::endl;
}
void caller2()
{
func(2);
func(0.2f);
}
//文件名main.cpp
void caller1();
void caller2();
int main()
{
caller1();
caller2();
return 0;
}
看代码可知caller1.cpp编译所得目标文件有func< int >及func< double >两个函数模板实例,而caller2.cpp编译所得目标文件有func< int >及func< float >两个函数模板实例。我们将这两个文件和main.c文件进行链接。
g++ caller1.o caller2.o main.o -o a.out
./a.out
func1: 1
func1: 0.1
func1: 2
func2: 0.2
从输出可以看出caller2()中本应该调用caller2.cpp中的func< int >,但是由于caller1.cpp和caller2.cpp中均有func< int >实例,并且函数参数列表也相同,那么链接时链接器基于函数名,模板实参列表以及参数列表判断两个函数模板实例等价,而将caller2.cpp中的func< int >除名。所有func< int >的调用都被链接到caller1.cpp中的func< int >实例。
在写链接命令如果将caller2.o放在caller1.o之前,结果会相反。