从VC++移植到GCC后的语法差异

开发
本文主要介绍了从VC++到GCC移植上存在的三点语法差异以及通过哪些改法可以消除这些差异,希望可以给读者带来帮助。

类型引用

 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(); i

  t != cont.end(); ++it) ...

  }

这里的Container::const_iterator同样需要改为typename Container::const_iterator。

#p#

基类成员引用

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显得简短。

#p#

交叉引用许可

  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()
   { ... }
   };

由于VC++对模板函数的迟编译,因此,一个模板类不只是可以调用一个尚未出现的类成员函数(或者访问其成员变量),甚至可以定义其实例。这种语法对C++来说确实显得怪异。因为等到编译后面的SomeClass时,他又可以在其函数中定义class Foo的实例,从而出现交叉引用的情况。这在非模板函数的情形下就算你用VC++亦难以做到。

遇到这种情况,该如何移植到GCC中?这个问题有点棘手。我个人认为出现这种情况是不太应该的,这意味着对类与类之间的关系混淆不清。你需要仔细审视一下这两个类正确的关系是什么。如果是移植库(例如WTL就有多处这样的情形)的过程中遇到这种情况,可以把函数的实现体改为放到类定义体外,如下:

class SomeClass;
  template
    class Foo
   {
   public: void foo(SomeClass& a);
   void foo2(); };
   class SomeClass
   {
   public: void some_func()
   { ... }
   };
   template inline void Foo::foo(SomeClass& a)
   {
   a.some_func();
   }
   template inline void Foo::foo2()
   {
   SomeClass a;
   a.some_func();
   }

【编辑推荐】

  1. 详解GCC的下载和安装
  2. GCC使用入门
  3. GCC 4.0的新特性
责任编辑:杨鹏飞 来源: IT专家网论坛
相关推荐

2010-01-27 17:42:58

VC++开发环境

2011-04-13 11:11:36

VC++托盘程序

2011-07-13 11:20:55

VC++ODBC

2010-01-21 17:22:21

VC++

2010-01-26 13:29:46

VC++应用程序

2010-01-27 15:11:17

VC++编译异常

2011-07-14 20:42:14

C++

2011-09-05 09:28:58

MySQLMongoDB

2013-09-02 15:49:38

DirectX 9Windows

2010-01-28 15:56:38

VC++ 6.0编译

2011-07-14 22:04:16

VC++

2011-05-13 15:31:24

VC++

2010-03-24 09:06:02

Visual Stui

2010-01-20 13:52:19

2010-03-04 10:04:10

Linux动态库

2011-12-14 09:46:14

LinuxUnix迁移

2009-12-09 13:29:17

VC++ 2005 E

2011-07-13 18:00:51

CC++VC

2010-01-22 10:44:10

VC++应用程序

2013-06-17 10:37:54

产品设计移动设计产品规划
点赞
收藏

51CTO技术栈公众号