草庐IT

cpp_exceptions_handling

全部标签

c++ - 如果在 user.hpp 中定义了 BOOST_NO_EXCEPTIONS,为什么不能编译 boost::shared_ptr

我有一个嵌入式系统,想在这个系统中使用boost,但需要禁用异常,因为我不想支付异常成本。boost给了一个user.hpp和可设置的宏选项BOOST_NO_EXCEPTIONS和BOOST_NO_EXCEPTION_STD_NAMESPACE,但是boost::shared_ptr不能编译(更准确的说,不能链接)如果定义了这两个宏。shared_ptr_boost.cpp:(.text._ZN5boost6detail12shared_countC2IiEEPT_[_ZN5boost6detail12shared_countC5IiEEPT_]+0x7a):undefinedrefe

Python3、Boost-Python 和 Cpp 链接器错误

所以我打算把我的笔记本电脑扔出窗外,然后去烧掉AppleHQ。查看以下更新:我无法让python3、boost-python和clang相互协作。我遇到的错误正在运行:clang++-ohello.sohello.cpp调用响应:Undefinedsymbolsforarchitecturex86_64:"__Py_NoneStruct",referencedfrom:boost::python::api::object::object()inhello-0c512e.o"_main",referencedfrom:implicitentry/startformainexecutabl

c++ - 调用 handle 为 NULL 的 CloseHandle(handle) 是否安全

删除NULL指针是安全的。int*p=NULL;deletep;//ok,secure句柄是什么?HANDLEh=NULL;CloseHandle(h);//allowed?我正在阅读MSDN但仍然不确定。它说了一些关于ERROR_INVALID_HANDLE的内容,但它是6L,而不是NULL。我来自一个类的析构函数,它给我一个C6387警告Errorif(m_hThread)WaitForSingleObject(m_hThread,INFINITE);CloseHandle(m_hThread);//warninigC6387m_hThread=NULL;

c++ - 如何判断 .cpp 文件在哪个项目中

我接手了一个解决方案中的C++代码。一个解决方案包含许多项目。我编辑了一个.cpp文件,但无法归档它属于哪个项目,所以我不知道要构建哪个项目。构建整个解决方案需要很长时间。如何找出.cpp文件属于哪个项目? 最佳答案 在VisualStudio中,单击编辑-查找和替换-在文件中查找上面写着“查找内容”的地方输入您感兴趣的文件的名称。其中显示“查看:”输入您要搜索的路径或使用[...]浏览按钮其中显示“查看这些文件类型:”输入*.vcxproj它应该在“查找结果”窗口中列出包含该文件的所有项目文件。

c++ - 包含在 header 或 cpp 中——Qt 中首选的是什么

当我写一个C++类时,我只在头文件中包含了特定情况。我更喜欢前向声明,我相信这是C++中的最佳实践。但是Qt类通常有很多属于标准Qt类的字段,因此将它们全部写在前向声明中似乎不是一个好主意。有什么首选方法吗?Qt有大量的文档,所以我认为它已经回答了我的问题,但我才刚刚开始阅读它。 最佳答案 我的规则是头文件只包含那些定义相关头文件使用的功能的文件。假设您在header中有指向某个类Foo的指针和引用,但header从未插入或实例化这些对象。在这种情况下,您不需要类的定义。您只需要一个前向声明。另一方面,如果您插入类型为Foo的对象,

c++ - 在 .cpp 或 .h 文件中,我应该在哪里包含头文件?

这个问题在这里已经有了答案:Wheretoputincludestatements,headerorsource?(9个回答)关闭9年前。我应该在.cpp文件还是.h文件中的什么地方包含头文件?我现在正在做一个项目,并试图想出一个干净的一劳永逸的方法。现在的状态是,包含文件在.cpp和.h文件中。例如,有时他们有#include在someFile.h中,有时在someFile.cpp中。我想知道,在何处执行包含重要吗?这两种方式都有效,但有什么陷阱吗?谢谢

c++ - 与 std::current_exception 关联的数据的生命周期

考虑以下代码:std::exception_ptreptr{std::current_exception()};constchar*msg=0;try{if(eptr!=std::exception_ptr{}){std::rethrow_exception(eptr);}}catch(conststd::exception&ex){msg=ex.what();}我可以在catch之外使用msg吗?换句话说,ex是否引用与eptr相同的异常实例?谢谢! 最佳答案 rethrow_exception的描述说:Throws:theexc

c++ - 为什么我们需要在编译期间包含 C 或 CPP 声明文件而不是像 iostream 这样的默认库?

如果C或CPP程序需要使用我们自己的带有声明的头文件和带有定义的cpp文件进行编译,我们需要在编译命令中包含带有定义的cpp文件(参见thisanswer)。但是,当我们写#include,我们不包括iostream.cpp在类似g++main.cppiostream.cpp-omain的编译语句中.如果我们编写自定义声明文件,例如hello.hpp带有类声明和hello.cpp有了定义,我们需要使用g++main.cpphello.cpp-omain编译它包括hello.hpp之后在标题中main.cpp文件。这是为什么?编辑:我们是否可以为我们的自定义头文件和cpp文件模仿标准模板

c++ - 构造函数和函数中的 CPP 引用

我对下面的代码有点困惑。`classsample{public:sample(){}sample(sample&Obj){}};voidfun(sample&Obj){}intmain(){samples(sample());fun(sample());return0;}出现以下错误由于以下错误,编译失败。main.cpp:在函数“intmain()”中:main.cpp:29:19:错误:从类型为“sample”的右值中对类型为“sample&”的非常量引用进行无效初始化fun(sample());我知道将fun中的参数从sample&obj更改为constsample&obj将解决

c++ - yaml-cpp 解析字符串

是否可以使用yaml-cpp解析YAML格式的字符串?没有YAML::Parser::Parser(std::string&)构造函数。(我通过libcurl从http服务器获取YAML字符串。) 最佳答案 尝试使用stringstream:std::strings="name:YAMLfromlibcurl";std::stringstreamss(s);YAML::Parserparser(ss); 关于c++-yaml-cpp解析字符串,我们在StackOverflow上找到一个类