草庐IT

boost-implicit-cast

全部标签

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++ - Static Cast 访问静态 const 类成员

这个问题在这里已经有了答案:Undefinedreferencetostaticconstint(9个回答)关闭5年前。所以昨天我正在寻找SO,但找不到以下问题的答案。这种情况来self正在使用的一些代码,但这里是MCVE来演示它。我在A.h中定义了一个类A,其中只有一个静态常量。我已经在标题中对其进行了初始化。#ifndefA_H_#defineA_H_classA{public:staticconstinttest=5;~A(){};};#endif/*A_H_*/然后我有一个B类需要从A类访问publicstaticconst。在这个例子中,它将把值深度复制到一个vector中。

c++ - 析构函数 : triviality vs implicit definition

根据我对标准的理解,普通析构函数是一种隐式声明的析构函数,其类只有基本和非静态成员以及普通析构函数。鉴于此定义的递归性,在我看来,唯一的“递归停止”条件是找到具有非隐式声明的析构函数(即用户声明的)的基类或非静态成员。如果那是对的,那应该意味着一个普通的析构函数是一个“不需要做任何事情”的析构函数,因此它将被声明(隐式地)但不被定义。换句话说:根据标准定义,隐式定义析构函数(即“它做某事”)不能是微不足道的说法是否正确?很抱歉提出这种愚蠢的问题,但我想澄清一下我的想法...... 最佳答案 没有。隐式定义的平凡析构函数根据定义是平凡

c++ - 如何用数据创建一个boost线程?

我在使用boost::bind和创建线程时遇到了一些问题。本质上,我想在“扫描仪”对象上调用“扫描”函数,使用绑定(bind)。像这样:Scannerscanner;intid_to_scan=1;boost::threadthr1(boost::bind(&scanner::scan));但是,我在语法上被绊倒了。如何将数据传递给扫描?作为构造函数的一部分? 最佳答案 请记住,任何成员函数的第一个参数都是对象。所以如果你想调用:scanner*s;s->scan()对于bind你会使用:boost::bind(&scanner::

c++ - 将带有 Boost 的 C++ 应用程序从 Linux 移动到带有 Visual Studio 6 的 Windows

2年前,我在Linux中使用Boost编写了一个小程序。现在我想让它在Windows中工作。我发现我的libs文件夹中几乎没有.a文件。我想知道如何让它在Windows中工作?我需要在Windows中构建Boost来获取库还是可以在某处下载?我正在使用VisualStudio6。 最佳答案 是的,您需要针对不同的平台重新编译。巧合的是,我在这个notlongago上发布了说明.我非常建议您不要使用VisualStudio6。它非常过时,而且非常不合规。您可以免费获得较新的版本,如Express。您不会错过任何东西。

c++ - 有什么理由更喜欢 static_cast 而不是一系列隐式转换?

假设我有一个实现多个接口(interface)的类classCMyClass:publicIInterface1,publicIInterface2{};并且在该类的一个成员函数中,我需要获得一个指向这些接口(interface)之一的void*指针(IUnknown::QueryInterface()中的典型情况。典型的解决方案是使用一个static_cast来实现指针调整:void*pointer=static_cast(this);如果没有从CMyClass继承的已知类,在这种情况下是安全的。但是如果这样的类存在:classCDerivedClass:publicCUnrelat

c++ - Boost序列化断言失败

我使用boost的二进制序列化,直到现在它运行良好。我有std::list指向序列化输出(oarchive)的指针,但序列化在对象的serialize()函数中失败,带有MSVC的对话框:R6010-abort()hasbeencalled这样的字符串被打印到控制台窗口中:Assertionfailed:0==static_cast(t)||1==static_cast(t),filec:\programfiles\boost\boost_1_44\boost\archive\basic_binary_oprimitive.hpp,line91这是什么意思?项目非常大,资源是分布式的,

c++ - boost UTF-16 字符串的库?

是否有任何boost库可以帮助处理UTF-16(或更高版本)字符串? 最佳答案 我用了ICU过去在处理C++编码时取得了成功。 关于c++-boostUTF-16字符串的库?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/6242387/

c++ - 什么时候需要 dynamic_cast?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:dynamic_castinc++这两种将派生类赋值给基类指针的方式有什么区别?Derivedd1;Base*b1=&d1Derivedd2;Base*b2=dynamic_cast&d2

c++ - boost::bind 不适用于 boost::tuple::get<N>()

我正在尝试使用boost::bind和STL与boost::tuple,但每次我尝试编译时都会收到以下错误。error:callofoverloaded‘bind(,boost::arg&)’isambiguous你知道我在这里做错了什么吗?为什么只针对boost::arg?谢谢AFG#include#include#include#include#include#include#includeintmain(intargc,constchar**argv){usingnamespaceboost::assign;typedefboost::tupleeth_array;std::ve