c – 将NULL指针转换为对象并调用其一个成员函数有实际的好处吗?

好的,所以我知道在技术上这是未定义的行为,但尽管如此,我已经在生产代码中看到了不止一次.如果我错了,请更正我,但我也听说有些人将这个“特征”用作现在C标准缺乏方面的一个合法的替代品,即无法获得地址(好的,偏移真的)一个成员函数.例如,这是普遍实现的PCRE(Perl兼容正则表达式)库:
#ifndef offsetof
#define offsetof(p_type,field) ((size_t)&(((p_type *)0)->field))
#endif

人们可以辩论,在这样的情况下,这种语言的微妙利用是否有效,甚至是必要的,但是我也看过这样使用:

struct Result
{
   void stat()
   {
      if(this)
         // do something...
      else
         // do something else...
   }
};

// ...somewhere else in the code...

((Result*)0)->stat();

这工作很好!它通过测试存在此方法避免了空指针取消引用,并且不尝试访问else块中的类成员.只要这些守卫到位,这是合法的代码吧?所以问题仍然存在:有没有一个实际的用例,哪里可以从使用这样的结构中获益?我特别关心第二种情况,因为第一种情况是更多的语言限制的解决方法.还是吗

PS.对于C风格的演员,不幸的是,人们仍然喜欢可以输入较少的.

解决方法

第一种情况不是调用任何东西.正在接收地址.这是一个定义的,允许的操作.它产生从对象开始到指定字段的以字节为单位的偏移量.这是非常非常普遍的做法,因为这样的偏移是非常普遍的需要.毕竟,并不是所有的对象都可以在堆栈上创建.

第二种情况是相当愚蠢的.明智的做法是声明该方法是静态的.

相关文章

对象的传值与返回说起函数,就不免要谈谈函数的参数和返回值...
从实现装饰者模式中思考C++指针和引用的选择最近在看...
关于vtordisp知多少?我相信不少人看到这篇文章,多半是来自...
那些陌生的C++关键字学过程序语言的人相信对关键字并...
命令行下的树形打印最近在处理代码分析问题时,需要将代码的...
虚函数与虚继承寻踪封装、继承、多态是面向对象语言的三大特...