草庐IT

builtin_object_size

全部标签

c++ - 是否在定义明确的非构造 "object"上调用非虚拟成员函数?

这个问题在这里已经有了答案:WhatwillhappenwhenIcallamemberfunctiononaNULLobjectpointer?[duplicate](6个答案)Whendoesinvokingamemberfunctiononanullinstanceresultinundefinedbehavior?(2个答案)关闭8年前。在构造函数中,允许调用非虚拟成员函数。根据这个事实是否可以得出以下代码段是明确定义的?structA{voidfoo{std::coutfoo();回答?借助评论中给出的一些链接以及链接页面中给出的链接,我现在认为可以找到答案,例如在http:

c++ - boost::variant for boost::arrays of arbitrary size

我想本着的spirit创建一个boost::varianttypedefboost::variant,boost::array,boost::array,...>any_int_array;泛化为N作为模板的第二个值。换句话说,一个包含任意大小数组的boost::variant。这可能吗?请注意,在上面的示例中,boost::array是我的案例之一,但对于采用单个int的任何类,它都需要是一个可行的解决方案值作为模板参数。 最佳答案 既然你在谈论具有静态已知容量的类型,你就不能用一些模板元编程来解决这个问题吗?LiveonColi

c++ - 2 个重载具有相似的转换 - 内置运算符 integer[pointer-to-object]

我有以下类(class):classDictionaryRef{public:operatorbool()const;std::stringconst&operator[](std::stringconst&name)const;//...};然后我尝试使用它:DictionaryRefref=...;ref["asdf"];//error输出提示两个重载,但只列出一个:1>...:errorC2666:'DictionaryRef::operator[]':2overloadshavesimilarconversions1>...:couldbe'conststd::string&D

c++ - 我可以在编译和链接时将 C++ 主函数和类与 Objective-C 和/或 C 例程分开吗?

我有一个小型C++应用程序,我导入了Objective-C类。它作为Objective-C++文件.mm工作,但任何包含header的C++文件可能最终包含一些Objective-Cheader,必须重命名为.mm扩展名以用于正确的GCC驱动程序。有没有办法为Objective-C类编写一个纯C++包装器,或者我能否以某种方式将Objective-C对象分离出来,然后单独链接它们?也许即使Objective-C类成为一个小库,我也可以在编译时静态重新链接?问题在于这段代码是跨平台的,在通常不使用Objective-C的系统(即非Mac)上编译起来比较困难。尽管预处理器命令限制了Obje

c++ - Objective-C 稳定的 ABI

我主要是一个C++人。由于C++缺少官方ABI,我总是使用类似COM的方法来设计支持多个编译器的组件。最近我遇到了一个问题,即Objective-C是否会替代类COM方法。显然,要让Objective-C成为替代品,需要一个稳定的ABI,因此我想知道是否存在用于Objective-C的稳定ABI(在所有主要操作系统[OSX、GNU/Linux、Windows]上)以及它有多容易它将使用Objective-C(++)作为不同编译器创建的组件之间的“粘合剂”。编辑:正如NikolaiRuhe指出的那样,对COM的简短描述可能会有所帮助。COM本质上是一种“二进制标准”,允许混合不同编译器(

c++ - Qt 信号/槽 : Is it an error to emit a signal from a temporary object?

在Qt中,如果从一个临时对象中调用一个信号,使得该对象可能在调用槽时被删除,这是一个错误吗?如果相关,代码会从临时对象的构造函数发出信号。(注意:没有指针或引用作为参数传递,所以这不是关于悬挂指针或引用的问题。我只是想知道,以最简单的形式,从Qt中的一个临时对象。)这是我的代码的简化版本://MyapplicationclassHandyApplication:publicQApplication{Q_OBJECTpublic:explicitHandyApplication(intargc,char*argv[]);signals:publicslots:voidhandySlot(

c++ - 在同一个赋值表达式中使用 std::move(object) 和 object.method() 。

下面表达式的结果是否定义明确?这是什么?hash_map[object.key()]=std::move(object);我不确定std::move部分的效果是否会发生在object.key()部分之前或之后,因此我的问题。 最佳答案 它的定义很明确,因为这段代码中的第一个并不重要:您可以将其重写为以下等价物hash_map[object.key()]=static_cast(object);关于代码我们能说些什么:object.key()应该在分配给map之前执行std::move(object)应在分配给map之前执行然后将对m

Python* 到 boost::python::object

我正在尝试用C++构建一个Python模块,将二维vector转换为Numpy二维数组。这里有什么不正确的地方-大概需要对PyObject*的boostpython对象进行一些转换?boost::python::objectbuild_day(intyear,intday){PyObject*arr;constintHEIGHT=5;constintWIDTH=5;std::vector>array(WIDTH,std::vector(HEIGHT));npy_intpdims[2]={WIDTH,HEIGHT};arr=PyArray_SimpleNewFromData(2,dims

C++ 后递增 : objects vs primitive types

我们不能对右值使用预增量:inti=0;intj=++i++;//Compileerror:lvaluerequired如果我们定义一个类:classA{public:A&operator++(){return*this;}Aoperator++(int){Atemp(*this);returntemp;}};然后我们可以编译:Ai;Aj=++i++;A对象和int数据类型有什么区别j=++i++;用A编译而不用int编译? 最佳答案 发生这种情况是因为当重载运算符被定义为成员函数时,它们遵循一些与调用成员函数更相关的语义,而不是内

c++ - 多重继承 : size of class for virtual pointers?

给定代码:classA{};classB:publicvirtualA{};classC:publicvirtualA{};classD:publicB,publicC{};intmain(){cout输出:sizeof(D)8每个类都包含自己的虚指针,但不包含其任何基类的虚指针,那么,为什么class(D)的Size是8? 最佳答案 这取决于编译器的实现。我的编译器是VisualStdioC++2005。代码如下:intmain(){cout会输出sizeof(B):4sizeof(C):4sizeof(D):8B类只有一个虚指针