V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Tony042
V2EX  ›  C++

C++ 模板类成员 Type alias 声明顺序

  •  
  •   Tony042 · 2020 年 8 月 5 日 · 1949 次点击
    这是一个创建于 1999 天前的主题,其中的信息可能已经有所发展或是发生改变。

    代码如下:

    template <typename List>
    class LargestTypeT;
    
    template <typename List>
    class LargestTypeT
    {
    private:
        using First = Front<List>;
        using Rest = typename LargestTypeT<PopFront<List>>::Type;
    
    public:
        using Type = IfThenElse<(sizeof(First) >= sizeof(Rest)), First, Rest>;
    };
    
    template <>
    class LargestTypeT<Typelist<>>
    {
    public:
        using Type = char;
    };
    
    template <typename List>
    using LargestType = typename LargestTypeT<List>::Type;
    

    在类 LargestTypeT 中 Type 的声明顺序是晚于 First 和 Rest 的,但是 Rest 可以成功成为 LargestTypeT<PopFront<List>>::Type 的别名呢(尽管 Type 在 Rest 之后声明)。我也尝试调换 private 和 public 的顺序(先声明 Type, 再声明 First,Rest)这样的话编译器就会报错( First and Rest are not declared )。我很好奇为什么 Type 类型可以先使用后声明呢,是不是跟模板展开有关?

    5 条回复    2020-08-05 20:08:46 +08:00
    codehz
        1
    codehz  
       2020 年 8 月 5 日 via Android
    是啊,这个属于参数依赖名字查找的范畴
    会在实例化的时候才进行决议
    (当然了,如果不是参数依赖的名字,仍然按照原始的顺序进行查找
    参考 ADL ODR 规则
    Tony042
        2
    Tony042  
    OP
       2020 年 8 月 5 日
    @codehz 好嘞,谢谢
    yazoox
        3
    yazoox  
       2020 年 8 月 5 日
    楼主,你在 using 别名时,为什么 有的 有`typename`,有的没有?
    elfive
        4
    elfive  
       2020 年 8 月 5 日 via iPhone
    @yazoox #3 你不用 typename 关键字,编译器不知道你 typename 后面的是个静态变量还是一个内部类型……
    Tony042
        5
    Tony042  
    OP
       2020 年 8 月 5 日
    @yazoox IfThenEls 和 Front 的定义就是一个模板内部类型,自然是不用的
    关于   ·   帮助文档   ·   自助推广系统   ·   博客   ·   API   ·   FAQ   ·   Solana   ·   866 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 22:53 · PVG 06:53 · LAX 14:53 · JFK 17:53
    ♥ Do have faith in what you're doing.