const_cast
é seguro apenas se você estiver lançando uma variável que originalmente não era const
. Por exemplo, se você tem uma função que recebe um parâmetro de a const char *
e passa um modificável char *
, é seguro const_cast
voltar a esse parâmetro para a char *
e modificá-lo. No entanto, se a variável original era de fato const
, o uso const_cast
resultará em um comportamento indefinido.
void func(const char *param, size_t sz, bool modify)
{
if(modify)
strncpy(const_cast<char *>(param), sz, "new string");
printf("param: %s\n", 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
objeto original por meio de umaconst
referência / ponteiro cancelado. Se, em vez disso, você estiver apenasconst_cast
tentando contornar uma API mal especificada (ou, no meu caso, preguiçosamente), que apenas aceita uma nãoconst
referência, mas será usada apenas emconst
métodos ... sem problemas.