Удалить базовый тип приведенного указателяC++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Удалить базовый тип приведенного указателя

Сообщение Anonymous »

Я видел этот код в проекте с открытым исходным кодом:
void EXPORT_API ReleaseDracoData(DracoData **data_ptr) {
if (!data_ptr) {
return;
}
const DracoData *const data = *data_ptr;
switch (data->data_type) {
case draco::DataType::DT_INT8:
delete[] static_cast(data->data);
break;
case draco::DataType::DT_UINT8:
delete[] static_cast(data->data);
break;
case draco::DataType::DT_INT16:
delete[] static_cast(data->data);
break;
case draco::DataType::DT_UINT16:
delete[] static_cast(data->data);
break;
case draco::DataType::DT_INT32:
delete[] static_cast(data->data);
break;
case draco::DataType::DT_UINT32:
delete[] static_cast(data->data);
break;
case draco::DataType::DT_FLOAT32:
delete[] static_cast(data->data);
break;
default:
break;
}
delete data;
*data_ptr = nullptr;
}

Мне интересно, поскольку это всего лишь базовые числовые типы, и деструктор вызывать не нужно, можем ли мы избежать переключения?
void EXPORT_API ReleaseDracoData(DracoData **data_ptr) {
if (!data_ptr) {
return;
}
const DracoData *const data = *data_ptr;
delete[] static_cast(data->data);
delete data;
*data_ptr = nullptr;
}


Подробнее здесь: https://stackoverflow.com/questions/783 ... basic-type
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»