Я не уверен, что мой подход к пользовательским исключениям правильный. То, что я хочу сделать, это выбросить исключения с пользовательскими сообщениями, но кажется, что я создал утечку памяти …
class LoadException: public std::exception {
private:
const char* message;
public:
LoadException(const std::string message);
virtual const char* what() const throw();
};LoadException::LoadException(const std::string message) {
char* characters = new char[message.size() + 1];
std::copy(message.begin(), message.end(), characters);
characters[message.size()] = '\0';
this->message = characters;
}
Я использую это следующим образом:
void array_type_guard(Local<Value> obj, const std::string path) {
if (!obj->IsArray()) {
throw LoadException(path + " is not an array");
}
}
try {
objects = load_objects();
} catch (std::exception& e) {
ThrowException(Exception::TypeError(String::New(e.what())));
return scope.Close(Undefined());
}
Я боюсь, что созданный в конструкторе массив никогда не удаляется. Но я не уверен, как удалить его — я должен добавить деструктор или, может быть, использовать совершенно другой подход?
Обновить:
Я на самом деле пытался использовать строковый класс следующим образом:
class LoadException: public std::exception {
private:
const char* msg;
public:
LoadException(const std::string message);
virtual const char* what() const throw();
};
LoadException::LoadException(const std::string message) {
msg = message.c_str();
}
const char* LoadException::what() const throw() {
return msg;
}
Но тогда я не могу получить сообщение об ошибке — какой-то случайный вывод отображается, когда я печатаю «что ()».
Вы можете воспользоваться std:string
class LoadException: public std::exception {
private:
std::string message_;
public:
explicit LoadException(const std::string& message);
virtual const char* what() const throw() {
return message_.c_str();
}
};LoadException::LoadException(const std::string& message) : message_(message) {
}
Тогда область видимости C ++ позаботится о том, чтобы все очистить для вас.
Как насчет
throw std::runtime_error("My very own message");
В конструкторе у меня есть
Printer::Printer(boost::asio::io_service& io, unsigned int interval) {
if (interval < 1) {
throw std::runtime_error("Interval can't be less than one second");
}
}
И при создании объекта
try {
Printer p{io, 0};
} catch (std::exception& e) {
std::cerr << e.what() << std::endl;
}
программа выйдет с выданным сообщением.