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

请问大佬们下面这样的代码是 UB 么?

  •  
  •   wutiantong · 2018-12-18 17:50:02 +08:00 · 2331 次点击
    这是一个创建于 1949 天前的主题,其中的信息可能已经有所发展或是发生改变。
    #include <iostream>
    
    template<std::size_t D>
    struct FakeNest
    {
        int & get() noexcept { return all_[0]; }
        FakeNest<D-1> &sub() noexcept { return *reinterpret_cast<FakeNest<D-1> *>(&all_[1]); }
        private: int all_[D];
    };
    
    int main()
    {
        FakeNest<4> a;
        a.sub().sub().get() = 666;
        std::cout << *(&a.get() + 2) << std::endl;
    }
    

    结果是符合预期的,但总觉得这种写法有点太作弊了,算不算 UB 呢?

    几个可能相关的 topic 是:

    1. reinterpret_cast
    2. pointer-interconvertible
    3. Standard_layout
    第 1 条附言  ·  2018-12-19 17:06:42 +08:00
    我今天看了很久这方面的资料,学到了很多新的知识点。有兴趣的话不妨在这个问题上做一些深入了解。
    2 条回复    2018-12-19 09:57:59 +08:00
    chinuno
        1
    chinuno  
       2018-12-18 19:04:44 +08:00 via Android
    算是 ub。看编译器实现吧。早期的 c++编译器对象模型是每个对象内存既带成员又带函数指针不能这样玩。现在的各个编译器如果不带虚函数不是虚继承基本上跟 c 结构体一样的内存分布用起来没问题,但是不能保证以后哪次更新编译器实现变了还能保持工作
    lrxiao
        2
    lrxiao  
       2018-12-19 09:57:59 +08:00
    FakeNest<D-1> 和 int 不 pointer-interconvertible 啊
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1082 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 23:24 · PVG 07:24 · LAX 16:24 · JFK 19:24
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.