一个TU中的模板专门化被另一个TU隐藏
Template specialisation in one TU hidden by another TU
我有一个类模板,它可以特殊化,以便更改用户定义类型的实用程序函数的行为。
我有一个翻译单元,它使用实用函数,我的类型的专门化可用。使用专门化。
在一个单独的翻译单元中,如果我调用效用函数而不包括专门化,它会改变另一个TU的行为(专门化不在两个 TU 中使用)
下面是一个完整的例子来描述我的问题: check.h
:定义了类模板,该类模板可以专门用于用户定义的类型
#pragma once
#include <iostream>
template<typename T>
struct Check
{
static void type();
};
template<typename T>
void Check<T>::type()
{
std::cout << "check fall-backn";
}
template<typename T>
void check(T&&)
{
Check<T>::type();
}
type.h
:我的用户定义类型
#pragma once
enum Foo
{
FOO,
BAR
};
type_check.h
: 专门为Foo
Check
#pragma once
#include "type.h"
#include "check.h"
template<>
struct Check<Foo>
{
static void type()
{
std::cout << "check Foon";
}
};
lib.h
: 你头文件
#pragma once
void lib();
lib.cpp
:TU源文件-使用type_check.h
#include "lib.h"
#include "type_check.h"
void lib()
{
check(FOO);
}
main.cpp
:
#include "check.h"
#include "type.h"
#include "lib.h"
#include "type_check.h" // uncomment this to make specialisation avail to all
int main()
{
check(5);
lib();
// check(FOO); // uncomment this to change behaviour of lib()`
return 0;
}
结果:
在main
中调用lib()
而不调用check(FOO)
会导致以下结果:
check fall-back
check Foo
在main
中调用lib()
和check(FOO)
的结果如下:
check fall-back
check fall-back <-- main changes behaviour of lib
check fall-back
在main.cpp
中包含type_check.h
,然后在main
中调用lib()
和check(FOO)
,结果如下:
check fall-back
check Foo
check Foo
问题:
当Check<Foo>
专门化不可用时,为什么在单独的TU中调用check(FOO)
将其从lib.cpp
的过载集中移除?
指出:
我不能只是把Check<Foo>
专门化在同一个文件作为Foo
的定义,因为Foo
实际上是一个生成的文件(protobuf)
这违反了一个定义规则。链接器会看到同一个函数的两个函数定义,并从中选择一个。不需要诊断。
在这种情况下,void Check<Foo>::type
通过lib.cpp中使用的check.h模板定义的实例化来定义一次,而另一个定义来自main.cpp中使用的type_check.h。
相关文章:
- 删除一个线程上有数百万个字符串的大型哈希映射会影响另一个线程的性能
- 运行同一解决方案的另一个项目的项目
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- C++从另一个类访问公共静态向量的正确方法是什么
- C++-试图将函数指针推回到另一个CPP文件中的矢量时出错
- 使用std::transform将一个范围的元素添加到另一个范围中
- 输入到文件并输出到另一个文件,并将流文件传递给函数
- 我可以将一个用clang c++11编译的对象与另一个用c++17编译的对象链接起来吗
- 修改函数中的指针(将另一个指针作为参数传递)
- 为什么我不能将一个对象push_back到属于另一个类的对象向量中?
- C++试图读取一个文件并输出到另一个文本文件
- 如何将指针从一个void函数传递到另一个C++
- 如何从另一个文件继承私有成员变量和公共函数
- 使用.find函数在c++中查找字符和另一个字符之间的大小
- 在 Windows 上,是否可以让 dll 在不使用 PATH 环境变量的情况下在另一个文件夹中查找依赖项?
- 在他自己的方法中,有可能将一个对象取消引用到另一个对象吗
- C++-我可以创建另一个类的成员并在构造函数中使用它吗
- 如何在C++中将函数发送到另一个进程
- 一个TU中的模板专门化被另一个TU隐藏