繁体   English   中英

如何使用 const_cast?

[英]How to use const_cast?

我的Student类中有一个私有变量定义为:

const int studentNumnber;

我正在尝试为Student编写一个复制构造函数,我需要抛弃 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);
    }

那不起作用......我不确定语法。

不允许const_cast变量实际上是const 这会导致未定义的行为。 const_cast用于从最终引用非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 以下是不允许的:

const int i = 0;
const int& ref = i;
const int* ptr = &i;

const_cast<int&>(ref) = 3;
*const_cast<int*>(ptr) = 3;

因为这里iconst并且您正在通过为其分配一个新值来修改它。 代码会编译,但它的行为是未定义的(这可能意味着从“它工作得很好”到“程序会崩溃”。)

您应该在构造函数的初始值设定项中初始化常量数据成员,而不是在构造函数的主体中分配它们:

Student(const Student & s) 
    : Person(p.getName(), p.getEmailAddress(), p.getBirthDate()),
      school(0),
      studentNumber(s.studentNumber)
{
    // ...
}

在您的代码中,您正在尝试转换此指针而不是变量。 您可以尝试以下操作:

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;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM