小编ori*_*n93的帖子

条件运算符的局限性?:

我正在使用GCC 4.5,并观察到非常奇特的行为.我想知道这个运算符是否有什么我不完全理解的东西.我以为我精通C++.我有一个Wnd用于Windows HWND对象的精简C++包装类,它具有一个实现的强制转换操作符operator HWND ....

如果我像这样使用条件运算符(给定输入Wnd *p和示例函数SetParent(HWND)):

SetParent((p!=NULL) ? (HWND)(*p) : NULL)
Run Code Online (Sandbox Code Playgroud)

父级正确设置为NULLp依赖.这就是我所期待的.但是,如果敢于懒惰并写下:

SetParent(p ? *p : NULL)
Run Code Online (Sandbox Code Playgroud)

事情变得混乱.在运行GDB之后,我发现p在调用之后调用了析构函数SetParent.有什么想法在这里发生了什么?

编辑 这是我的Wnd课程:

class Wnd{
        HWND m_hwnd;        ///< the actual handle
        WndFake *fake;      ///< store state here if we do not have a handle
    public:
        virtual ~Wnd();
        //contructor s
        Wnd(HWND wnd=NULL):m_hwnd(wnd),fake(NULL){}
        Wnd(DWORD sty,const jchar *title,const RECT &sz);
        operator HWND(){return m_hwnd;}
        operator HWND() const {return m_hwnd;} …
Run Code Online (Sandbox Code Playgroud)

c++ conditional destructor conditional-operator operator-keyword

6
推荐指数
1
解决办法
796
查看次数