VC编程之从VC++到GCC移植:谈两者语法差异
小标 2019-02-22 来源 : 阅读 1778 评论 0

摘要:本文主要向大家介绍了VC编程之从VC++到GCC移植:谈两者语法差异,通过具体的内容向大家展示,希望对大家学习VC编程有所帮助。

本文主要向大家介绍了VC编程之从VC++到GCC移植:谈两者语法差异,通过具体的内容向大家展示,希望对大家学习VC编程有所帮助。

VC编程之从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(); it != cont.end(); ++it) 
  ... 
  }
  这里的Container::const_iterator同样需要改为typename Container::const_iterator。
2
  基类成员引用
以下是引用片段:
  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显得简短。
3
  交叉引用许可
以下是引用片段:
  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(); 
  }    

以上就介绍了VC/MFC的学习,希望对VC/MFC有兴趣的朋友有所帮助。了解更多内容,请关注职坐标编程语言VC/MFC频道!

本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 1 不喜欢 | 0
看完这篇文章有何感觉?已经有1人表态,100%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式AI+学习就业服务平台 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved