实现cexception c 类时,要考虑的是什么
visual What are the things to take into consideration while implementing a CException c++ class
我尝试了一个简单的C cexception实现类,从std ::异常派生。我做错了什么,我应该添加更多,我应该改进什么?C 的例外是什么?目的是使其尽可能多地独立。代码如下:编辑:
class CeException: public std::exception {
public:
char* getascii(const wchar_t* msg)
{
char* pasc = new char[wcslen(msg) + 1 ];
wcstombs(pasc, msg, wcslen(msg) + 1);
return pasc;
}
CeException(const wchar_t* msg, char* pasc = NULL ):
exception(pasc = getascii(msg))
{
delete[] pasc;
}
CeException(const string msg)
{
}
virtual ~CeException()
{
}
BOOL GetErrorMessage(LPTSTR lpszError, UINT nMaxError, PUINT pnHelpContext = NULL )
{
const char* pasc = this->what();
wchar_t* puni = new wchar_t[strlen(pasc)+1];
mbstowcs(puni,pasc, strlen(pasc) + 1);
wcscpy_s(lpszError,nMaxError, puni);
delete[] puni;
return 0;
}
void Delete()
{
delete this;
}
};
我使用您的指示进行了最终实现的编辑。
通常您不需要在异常类中实现方法,因此看起来像这样:
class YourException : public std::runtime_error
{
public:
explicit YourException(const std::string & msg) :
std::runtime_error(msg)
{
}
};
我不明白有其他方法的原因。
您不应该从其构造函数中抛出异常。相反,客户端代码应引发您的异常:
throw YourException("Some error");
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- C++避免重复声明的语法是什么
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- C++中名称篡改的目的是什么
- 在 c++ 中拥有一组结构的正确方法是什么?
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 是什么阻止DOMTimerCoordinator::NextID进入无休止的循环
- 派生类销毁的最佳实践是什么
- 这个语法std::class<>{}(arg1, arg2) 在C++中是什么意思?
- 通过JNI传递数据数组的最快方法是什么
- "using namespace std;"在C++的作用是什么?
- 在两台机器之间进行时间戳的最佳c++chrono函数是什么
- 文件系统:复制功能的速度秘诀是什么
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 使用QQuickFramebufferObject时同步数据的最佳方式是什么
- 是什么原因导致它无法编译?它是声明签名还是在函数本身的实现中
- 实现cexception c 类时,要考虑的是什么