我的Student
类中有一个私有变量,定义为:
const int studentNumnber;
我正在尝试为学生编写一个复制构造函数,我需要抛弃constness来执行此操作,遗憾的是我不明白如何使用std::const_cast
。
这就是我在复制构造函数中尝试做的事情:
Student(const Student & s)
: Person(p.getName(), p.getEmailAddress(), p.getBirthDate()), school(0), studentNumber(0) {
school = new char[strlen(s.school) + 1];
strcpy_s(school, strlen(s.school) + 1, s.school);
const_cast<int*>(this)->studentNumber = s.studentNumber;
//studentNumber = s.studentNumber);
}
这不起作用......我不确定这样做的语法是什么。
答案 0 :(得分:68)
您不允许const_cast
变量实际为const
。这导致未定义的行为。 const_cast
用于从引用和指针中删除常量,这些引用最终引用的内容不是const
。
所以,这是允许的:
int i = 0;
const int& ref = i;
const int* ptr = &i;
const_cast<int&>(ref) = 3;
*const_cast<int*>(ptr) = 3;
这是允许的,因为分配给的对象i
不是const
。以下是不允许的:
const int i = 0;
const int& ref = i;
const int* ptr = &i;
const_cast<int&>(ref) = 3;
*const_cast<int*>(ptr) = 3;
因为此处i
为const
而您正在通过为其指定新值来修改它。代码将编译,但其行为是未定义的(这可能意味着从“它工作正常”到“程序将崩溃”。)
您应该在构造函数的初始值设定项中初始化常量数据成员,而不是在构造函数体中分配它们:
Student(const Student & s)
: Person(p.getName(), p.getEmailAddress(), p.getBirthDate()),
school(0),
studentNumber(s.studentNumber)
{
// ...
}
答案 1 :(得分:-3)
在您的代码中,您尝试使用此指针而不是变量。您可以尝试以下方法:
Student(const Student & s)
: Person(p.getName(), p.getEmailAddress(), p.getBirthDate()), school(0), studentNumber(0) {
school = new char[strlen(s.school) + 1];
strcpy_s(school, strlen(s.school) + 1, s.school);
*const_cast<int*>(&studentNumber) = s.studentNumber;
}