- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在将 BOOST 移植到我的 TI 嵌入式平台,在嵌入式环境中不支持异常是很常见的,所以我的 TI 嵌入式平台支持。所以我使用 BOOST_EXCEPTION_DISABLE 和 BOOST_NO_EXCEPTIONS 按照 BOOST CONFIG http://www.boost.org/doc/libs/1_56_0/libs/config/doc/html/index.html 的指导从 BOOST 中删除异常
但有趣的是,对于 bad_weak_ptr,它被声明为派生自 std::exception 而没有任何宏:
#if defined(__BORLANDC__) && __BORLANDC__ <= 0x564
# pragma option push -pc
#endif
class bad_weak_ptr: public std::exception
{
public:
virtual char const * what() const throw()
{
return "tr1::bad_weak_ptr";
}
};
#if defined(__BORLANDC__) && __BORLANDC__ <= 0x564
# pragma option pop
#endif
请问,如何将BOOST中的bad_weak_ptr去掉?为什么 BOOST 不给出一个宏来切割异常依赖类,以防异常本身已经被切割?
最佳答案
如果必须的话,有一些肮脏的技巧可以解决这个问题。如果您在适当命名的头文件中创建自己的 std::exception 类并将其放在包含路径的第一位,则编译器应该取而代之。但是要意识到这应该被很好地记录下来,因为它是一个 hack。
从更广泛的意义上讲,我认为您或许应该首先考虑为什么要使用 Boost。 Boost 占用空间更大,并非为小型系统设计。 BOOST_NO_EXCEPTIONS 解决方案与正确的错误传播和处理相去甚远。在我看来,更好的选择是采用 Boost——异常和所有,或者使用其他更合适的东西。
关于c++ - 为什么没有宏来切割从 std::exception 派生的 bad_weak_ptr,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26500020/
我正在学习智能指针和shared_from_this。在Class Inheritance Relations中,会很难理解。 我有两个基类CA和CB,它们派生自enable_shared_from_
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: enable_shared_from_this - empty internal weak pointer?
我想创建一些 Timer 类,它每 N 秒打印一次“文本”,其中 N 将在构造函数中初始化。 #include #include #include #include class Timer :
我使用 boost asio 和 beast(用于浏览器支持)开发桌面聊天。 我使用这个架构: 但是,在构建时,我遇到了一个问题:bad_weak_ptr,我不知道哪里出了问题:s这是源代码的链接 h
我试图将一个共享指针从 QTGUI 类传递到 Client 类,但一直收到 bad weak ptr 错误。我读到我不能直接在构造函数中分配 shared_from_this(),因为此时指针还没有准
当我这样做时出现异常:std::bad_weak_ptr->shared_from_this() template class painter_record_t { ....... private:
我正在尝试在 asio 中保留已连接客户端的列表。我已经从文档 (http://www.boost.org/doc/libs/1_57_0/doc/html/boost_asio/example/cp
我想了解为什么在调用 shared_from_this 时会出现 bad_weak_ptr 异常。 #include #include class parent : public std::ena
我开发了一些可以正确编译但在(调试)运行时失败的代码。我正在使用 VS2015。 背景:我正在构建一个高级消息引擎。为了使新消息的编程添加可维护,在生产代码中,我花时间使用 explicit init
我有一个 SuperParent 类,一个 Parent 类(派生自 SuperParent)并且都包含一个 shared_ptr到一个 Child 类(它包含一个 weak_ptr 到一个 Supe
为了创建我的 EventManager,我需要创建一些函数,这些函数会使用 Listeners 的 shared_ptr 将它们存储到 vector 中并调用它们的事件函数。我这样做了,它工作正常,除
我正在将 BOOST 移植到我的 TI 嵌入式平台,在嵌入式环境中不支持异常是很常见的,所以我的 TI 嵌入式平台支持。所以我使用 BOOST_EXCEPTION_DISABLE 和 BOOST_NO
我有一个基类和一个派生类。 API 仅公开 Derived,而实现隐藏在 Base 中(gcc 属性 visibility 设置为 hidden ),因为一些内部 API 模块必须调用 Base 方法
编辑:我从来没有弄明白这一点——我重构了代码,使其与 Boost 示例几乎相同,但问题仍然存在。如果其他人遇到此问题,则您的问题可能是更常见的 shared_from_this() 在不存在 shar
我定义了一个类似于下面的类: class A : std::enable_shared_from_this { public: static std::shared_ptr create() {
我试图理解 std::enable_shared_from_this 类的行为,但我无法理解。所以我写了一个简单的程序来测试不同的情况。 问题 谁能解释一下下面代码的行为,因为我无法解释观察到的结果。
我正在使用独立的 Asio 和 C++11 创建一个 C++ 服务器应用程序,但遇到错误,这就是我寻求帮助的原因。 错误 在类里面worker_thread , 在通话期间 shared_from_t
首先,我已阅读列出的所有相关问题。 他们说,“在使用 shared_from_this 之前,你必须有一个指向 this 的现有 shared_ptr。”据我所知,我绝不会违反该条件。我将 Foo 的
首先,这个问题似乎与同时使用 clang(任何版本)和高于 6.5.0 版本的 libstdc++ 有关。 我在我的代码库中使用以下习惯用法来对用户隐藏实现: #include class mycl
这个问题在这里已经有了答案: std::enable_shared_from_this: is it allowed to call shared_from_this() in destructor
我是一名优秀的程序员,十分优秀!