读loki有感,编译阶段发现两个类能否转化

简介: 读loki有感,编译阶段发现两个类能否转化

开发环境:VS2005(VC8)

以下代码在VS2002上运行不了,据说VS2002(VC7)不完全支持偏特化,VS2003(VC7.1)就支持了。

问题提出:

一,已知类型T,U,在编译阶段如何知道T能否转化成U。

template <class T, class U>
struct ConversionHelper
{
static long   Test(...);//WQ注:C++中,不定参数已不需要“至少一个定参”了。
 static short Test(U);
 static T MakeT();
};
template <class T, class U>
struct Conversion
{
 typedef ConversionHelper<T, U> H;
 enum { exists = sizeof(short) == sizeof(H::Test(H::MakeT())) };
};
class A
{
public:
 A()
 {
  TRACE("\r\nAr\n");
 }
};
class  B : public A
{
public:
 B()
 {
  TRACE("\r\nBr\r\n");
 }
};

测试代码:

bool b1 = Conversion<B,A>::exists;
bool b2 = Conversion<A,B>::exists;

运行结果分别为true,false.

二,接上面的问题。如果T能转化成U,则定义一个U类型的对象,否则定义T类型的变量。

template <int flag, typename T, typename U>
 struct Select  
 {
  typedef U Result;
 }; 
 template <typename T, typename U>
 struct Select<0, T, U>
 {
  typedef T Result;
 };

测试代码:

Select<Conversion<B,A>::exists,B,A>::Result type;

type的类型是A;B不再继承与A,则type类型是B。


相关文章
|
2天前
|
前端开发 Java 测试技术
[AIGC] 请举例说明在运行时读取注解的应用场景。
[AIGC] 请举例说明在运行时读取注解的应用场景。
|
1月前
|
SQL 分布式计算 API
Apache Hudi从零到一:深入研究读取流程和查询类型(二)
Apache Hudi从零到一:深入研究读取流程和查询类型(二)
51 1
|
2月前
|
分布式计算 DataWorks 数据处理
DataWork数据处理问题之属性覆盖掉如何解决
DataWork数据处理是指使用DataWorks平台进行数据开发、数据处理和数据治理的活动;本合集将涵盖DataWork数据处理的工作流程、工具使用和问题排查,帮助用户提高数据处理的效率和质量。
27 0
|
3月前
|
存储 消息中间件 分布式计算
流计算中的状态管理是什么?请解释其作用和常用方法。
流计算中的状态管理是什么?请解释其作用和常用方法。
25 0
|
3月前
|
存储 Java API
Flink中的状态管理是什么?请解释其作用和常用方法。
Flink中的状态管理是什么?请解释其作用和常用方法。
30 0
|
存储 自然语言处理 编译器
程序环境和预处理(基本定义与实例使用)
程序环境和预处理(基本定义与实例使用)
73 0
程序环境和预处理(基本定义与实例使用)
|
SQL 数据采集 分布式计算
数据预处理-数据解析-读取规则及加载到广播变量|学习笔记
快速学习数据预处理-数据解析-读取规则及加载到广播变量
224 0
数据预处理-数据解析-读取规则及加载到广播变量|学习笔记
编程小技巧8-优化日志对象创建代码
编程小技巧8-优化日志对象创建代码
|
自然语言处理
在以阶段划分的编译过程中,判断程序语句的形式是否正确属于()阶段的工作。
在以阶段划分的编译过程中,判断程序语句的形式是否正确属于()阶段的工作。
127 0