你好,欢迎来到电脑编程技巧与维护杂志社! 杂志社简介广告服务读者反馈编程社区  
合订本订阅
 
 
您的位置:技术专栏 / C专栏
从VC++到GCC移植:谈两者语法差异(1)
 
类型引用

以下是引用片段:
  template
  class Foo
  {
  typedef T::SomeType SomeType;
  };

  这段代码在VC++中一点问题也没有,但是GCC并不允许,因为它不知道T::SomeType是什么。你需要改为:

以下是引用片段:
  template
  class Foo
  {
  typedef typename T::SomeType SomeType;
  };

  通过typename T::SomeType告诉GCC,SomeType是一个类型名,而不是其他东西。

  当然,这种情况不只是出现在typedef中。例如:

以下是引用片段:
  template
  void visit(const Container& cont)
  {
  for (Container::const_iterator it = cont.begin(); it != cont.end(); ++it)
  ...
  }

  这里的Container::const_iterator同样需要改为typename Container::const_iterator。
基类成员引用

以下是引用片段:
  template
  class Foo : public Base
  {
  public:
  void foo() {
  base_func();
  m_base_member = 0;
  }
  };

  这段代码在VC++中同样没有问题,但是GCC中不能通过。因为GCC并不知道base_func,m_base_member是什么。对于这个问题,你可以有两种改法:

  改法1:加上域作用符Base::

以下是引用片段:
  template
  class Foo : public Base
  {
  public:
  void foo() {
  Base::base_func();
  Base::m_base_member = 0;
  }
  };

  改法2:使用using指示符

以下是引用片段:
  template
  class Foo : public Base
  {
  public:
  using Base::base_func;
  using Base::m_base_member;
  void foo() {
  base_func();
  m_base_member = 0;
  }
  };

  这两种方法各有好处,在class Foo中出现大量的Base::base_func、m_base_member的引用时,使用using是方便的。而如果只有一次,那么方法1显得简短。
交叉引用许可

以下是引用片段:
  class SomeClass;
  template
  class Foo
  {
  public:
  void foo(SomeClass& a) {
  a.some_func();
  }
  void foo2() {
  SomeClass a;
  a.some_func();
  }
  };
  class SomeClass
  {
  public:
  void some_func() {
  ...
  }
  };

(编辑:aniston)

  推荐精品文章

·2024年9月目录 
·2024年8月目录 
·2024年7月目录 
·2024年6月目录 
·2024年5月目录 
·2024年4月目录 
·2024年3月目录 
·2024年2月目录 
·2024年1月目录
·2023年12月目录
·2023年11月目录
·2023年10月目录
·2023年9月目录 
·2023年8月目录 

  联系方式
TEL:010-82561037
Fax: 010-82561614
QQ: 100164630
Mail:gaojian@comprg.com.cn

  友情链接
 
Copyright 2001-2010, www.comprg.com.cn, All Rights Reserved
京ICP备14022230号-1,电话/传真:010-82561037 82561614 ,Mail:gaojian@comprg.com.cn
地址:北京市海淀区远大路20号宝蓝大厦E座704,邮编:100089