背景: #EDF0F5 #FAFBE6 #FFF2E2 #FDE6E0 #F3FFE1 #DAFAF3 #EAEAEF 默认  
阅读新闻

初学者编程入门:C++学习实用技巧讲解

[日期:2008-02-17] 来源:互联网  作者:佚名 [字体: ]

  在准标准C++中,有关缺省变量值的限制非常模糊。基于此,很多编译器允许开发人员将缺省变量值包含在函数声明,指向函数的指针和引用,成员函数的指针,以及typedef声明中。

  请看一下以下的程序:

  struct A
  {
  void func(int x=5)
  {
  }
  };
  void g(int n=12)
  {
  }
  // 根据C++标准,不能在以下声明中使用缺省变量值。
  void (*pf)(inti=120);
  void (A::*pmf)(int j=50);
  typedef void (*PF)(inti=100);
  // 函数的引用
  typedef void (&PRF)(inti=100);
  int main()
  {
  pf=g;
  PF pf2=g;
  pmf=&A::func;
  A a;
  //这些调用使用了哪些缺省值?
  pf();
  pf2();
  (a.*pmf)();
  }

  A::func()和g()具有缺省变量值,这是合理的。然而,指针pmf,pf以及typedefPF也定义了缺省的变量值。根据C++标准,这是不规范的。

  这一代码的实际使用中,其中的一个问题是这些声明中提供的缺省值与A::func()和g()函数提供的值不一致。也就是说,很多编译器将这些代码作为非标准的扩展。当调用g()函数时,我的编译将120作为pf的缺省值;然而,对于pf2,它使用100作为它的缺省值。

  作为一种规则,应该避免使用指向函数的指针,成员函数的指针,以及typedef命名的缺省变量值。即使你的编译器接受了它们,在更高版本中它也可能不被接受。而且,这些代码也会降低程序的灵巧性,也会给那些无法判别哪些编译器接收何种缺省变量的开发人员带来误导。在使用这些缺省变量值的合法代码中,这里的建议是添加一些必要的注释,以说明需要哪些缺省变量值。

 文章如转载,请注明:转载自[三十夜网站]

录入:30ye.com

推荐 】 【 打印
上一篇:
下一篇:Oracle数据库开发经验积累(一)
相关新闻      

本文评论       全部评论
发表评论


点评: 字数
姓名:

  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款