const_cast 安全吗? [英] Is const_cast safe?

查看:33
本文介绍了const_cast 安全吗?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我找不到关于 const_cast 的太多信息.我能找到的唯一信息(在 Stack Overflow 上)是:

I can't find much information on const_cast. The only info I could find (on Stack Overflow) is:

const_cast<>() 用于添加/删除变量的 const(ness)(或 volatile-ness).

The const_cast<>() is used to add/remove const(ness) (or volatile-ness) of a variable.

这让我很紧张.使用 const_cast 会导致意外行为吗?如果是,那是什么?

This makes me nervous. Could using a const_cast cause unexpected behavior? If so, what?

或者,什么时候可以使用 const_cast?

Alternatively, when is it okay to use const_cast?

推荐答案

const_cast 仅在您强制转换最初非const 的变量时才是安全的.例如,如果你有一个函数接受一个 const char * 的参数,并且你传入了一个可修改的 char *,那么 const_cast 是安全的code> 将该参数恢复为 char * 并修改它.但是,如果原始变量实际上是 const,那么使用 const_cast 将导致未定义的行为.

const_cast is safe only if you're casting a variable that was originally non-const. For example, if you have a function that takes a parameter of a const char *, and you pass in a modifiable char *, it's safe to const_cast that parameter back to a char * and modify it. However, if the original variable was in fact const, then using const_cast will result in undefined behavior.

void func(const char *param, size_t sz, bool modify)
{
    if(modify)
        strncpy(const_cast<char *>(param), sz, "new string");
    printf("param: %s
", param);
}

...

char buffer[16];
const char *unmodifiable = "string constant";
func(buffer, sizeof(buffer), true);  // OK
func(unmodifiable, strlen(unmodifiable), false); // OK
func(unmodifiable, strlen(unmodifiable), true);  // UNDEFINED BEHAVIOR

这篇关于const_cast 安全吗?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆