这两种方法有什么区别?
有时当我遇到编译时错误提示编译器无法识别 一些类类型在函数签名中,那么如果我在各自的变量前面加上关键字“class”,它总是可以解决这种编译时错误。
例如,如果编译器无法识别
中的 Client 类型void recv( Client * c )
如果我把它改成
void recv( class Client * c )
问题解决了。
很抱歉,由于我随机想到了这个问题,所以无法想出具体的例子。
最佳答案
在类型参数声明中使用关键字 class、struct、enum 称为详细类型说明符。它在声明函数的范围内引入新类型。 它类似于前向声明。
这种声明还有另一种用法。例如,如果对象名称或函数名称隐藏了具有相同名称的类或枚举。例如
struct A {};
A A; // now A is seen as an identifier of the object
void f( struct A );
关于c++ - 使用 "class "关键字声明一个变量 vs 在函数签名中声明一个没有 "class"关键字的变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21880389/