c++ 表达式必须包含类类型 VC_error_code:c2228
———
这样的错误一般发生在使用’.’进行访问时,原因可能在于:
- 你以为你定义了一个类对象,其实你是声明了一个函数,在编译器看来;
- 对类对象指针采用.的方式访问其成员变量;
第一种原因
我们列出会出该错误的代码
class ClassName {
public:
ClassName(){}
ClassName(int In_val) {_val=In_val};
void foo() {}
private:
int _val;
};
int main(int argc, char *argv[]) {
ClassName x(1);
x.foo();
ClassName y();
y.foo(); // error
return 0;
}
在上面这个简单例子中” y.foo() “这句话会报错,原因是就是:编译器将” ClassName y(); “当成了一个函数处理了。
类似于下面例子的效果。
class ClassName {
public:
ClassName() {}
ClassName(int In_val) { _val = In_val }; //
void foo() {}
private:
int _val;
};
int main(int argc, char *argv[]) {
ClassName x(1);
x.foo();
ClassName y(); //被当成声明在函数中的函数了
ClassName z = y();
z.foo(); // pass
//y.foo(); // error
return 0;
}
ClassName y() {
return ClassName(233);
}
所以,我们如果要使用无参数的默认构造函数的时候应该如下的写法:
ClassName ClassVal;
ClassName ClassVal = ClassName(); // 可能还有其他的写法
第二种原因
class ClassName {
public:
ClassName(){}
ClassName(int In_val) {_val=In_val}; //
void foo() {}
private:
int _val;
};
int main(int argc, char *argv[]) {
ClassName *x=new ClassName(233);
x.foo(); //error
delete x;
return 0;
}
错误的原因是,我们应该使用类指针的成员时使用“ -> ”,但是我们用成了 ” . “,导致了编译器报错。
正规写法常见有下面两种
class ClassName {
public:
ClassName(){}
ClassName(int In_val) {_val=In_val};
void foo() {}
private:
int _val;
};
int main(int argc, char *argv[]) {
ClassName *x=new ClassName(233);
x->foo(); // 方法一
(*x).foo(); // 方法二
delete x;
return 0;
}