类型引用
以下是引用片段: 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. } }. |
相关文章
WinXP下的8步快速设置无线网络
巧妙解决WindowsXP网络访问慢的难题
windows强化安全综合设置
在C 程序中添加逻辑流程控制
转:从VC 到GCC移植:谈两者语法差异
C_C 中动态链接库的创建和调用
谈函数指针(全局_类成员函数)和函数对象
A .NET效率陷阱之——Attributes
并非偏见也驳“驳’C语言已经死了’”
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛