草庐IT

the_struct

全部标签

C++ 销毁顺序 : Calling a field destructor before the class destructor

有没有办法在类析构函数之前调用字段析构函数?假设我有2个类Small和Big,Big包含一个Small的实例作为它的字段因此:classSmall{public:~Small(){std::cout当然,这会在小析构函数之前调用大析构函数:BigdestructorSmalldestructor我需要在Big析构函数之前调用Small析构函数,因为它会为Big析构函数执行一些必要的清理工作。我可以:显式调用small.~Small()析构函数。->但是,这会调用Small析构函数两次:一次显式调用,一次在Big析构函数执行后调用。有一个Small*作为字段并在Big析构函数中调用del

c++ - 玛雅编程 : Separating attributes into sections in the attribute editor

抱歉这么具体的应用程序,但我注意到另一篇关于Maya开发的回答很好的帖子。我刚刚为Maya编写了一个插件节点。它只是根据湍流函数杀死一堆粒子。湍流由许多可在属性编辑器中调整的属性驱动。在属性编辑器中,还有一些其他属性称为“缓存”和“节点状态”,它们位于湍流属性之前。这对用户来说看起来不太漂亮。我希望能够做的是在GUI中放置分隔线以将它们分开。如果您查看属性编辑器中的大多数其他Maya节点,它们就是这样做的。它们在面板上有水平可折叠栏,将不相关的属性彼此分开。我的简单问题是,如何告诉Maya创建这些可折叠条来拆分属性?感谢您提供的任何帮助。安迪 最佳答案

c++ - 在 C++ 中使用 .find() 和 struct 作为映射中的键

我无法访问BOOST或STL;我的结构和map看起来类似于以下伪装:structs_map_key{inta;intb;booloperatormyMap;for(inti=0;i::iteratorx=myMap.find(smk);if(x!=myMap.end()){std::coutfirst.afirst.b我想做的是在我的多重映射中搜索A=2、B=2或A&B=2的所有情况。我不太确定,但我想我需要在我的结构中创建谓词对于“发现”。想法? 最佳答案 operator这就是find所需要的或其他任何东西。但是,您的实现有一个

c++ - VS2008 : Disable warnings in included header files outside the project

这可能吗?我不想全局禁用警告,因为我想检查我自己的头文件是否有警告。 最佳答案 您可以禁用有关包含外部头文件的警告:#pragmawarning(push)#pragmawarning(disable:thewarning)//includehere#pragmawarning(pop)如果您需要多次包含标题,您可以使用编译指示创建一个标题并将其包含在内。问了同样的问题here. 关于c++-VS2008:Disablewarningsinincludedheaderfilesoutsi

c++ - "Name The Template Parameter"奇定义

template//whyisboolhere,classbooltype=bool.Aretheyequivalent?structif_{typedeftypenamettype;};templatestructif_//whatdoesthemean?{typedeftypenameutype;};代码来自一篇名为“命名模板参数”的文章。我无法理解both结构的定义。 最佳答案 编辑:首先移动最重要的部分:if_::type;//thisisintif_::type;//thisisdouble这很方便地定义了一个可以在编译时

c++ - ZMQ : Sending custom CPP object over the ZMQ queue

我有一个名为GenericMessage的类,显示在下面的第一个代码片段中(在GenericMessage.hxx中定义)。我有一个名为TestFE.cpp的.cpp文件(参见下面的第二个代码片段),它试图通过ZMQ队列发送类GenericMessage的实例(另请参见下面的第四个代码片段-ZmqHandler.hxx)。TesfFE.cpp通过包含ZmqHandler.hxx在此处实现ZMQ推送模式。我还有另一个名为TestBE.cpp的.cpp文件(请参阅下面的第三个代码片段),它通过ZMQ队列接收上述GenericMessage实例。TestBE.cpp在此处实现ZMQ拉模式以通

c++ - BOOST_FUSION_ADAPT_TPL_STRUCT 和模板数组大小

由于BOOST_FUSION_ADAPT_TPL_STRUCT,我正在尝试迭代C++模板结构.我的结构包含固定大小的多维数组,其大小是模板参数。如果我们考虑修改Boost的示例以解决我的问题:#include#include#include#include//Example://http://www.boost.org/doc/libs/1_53_0/libs/fusion/doc/html/fusion/adapted/adapt_tpl_struct.htmlnamespacedemo{templatestructemployee{Namename;Ageage;Tar[SIZE1

c++ - sizeof pragma packed bitfield struct 数组

我将VisualStudio2013用于x64系统。我有以下结构:#pragmapack(1)structTimeStruct{intmilliseconds:10;BYTEseconds:6;BYTEminutes:6;BYTEhour:5;BYTEday:5;};#pragmapack()和一个数组:TimeStructstArray[10];当我使用sizeof(stArray);时,我得到80而不是40。我需要知道问题是编译器没有正确打包还是sizeof没有考虑位域的实际大小。谢谢 最佳答案 参见WhatisVC++doin

c++ - 为什么使用 extern struct {} foo,会触发无效的 fPIC required 错误消息?

我正在构建一个共享库,它具有如下所示的相应代码和编译规则://x.Cstruct{shortlen;chars[32700];}foo;//u.Cexternstruct{shortlen;chars[32700];}foo;voidblah(void){foo.s[0]=0;}$CXX-cx.C-fPIC$CXX-cu.C-fPIC$CXX-shared-ox.so.1-Wl,-soname,x.so.1x.ou.o此代码使用intel(v13-v16)编译器和clang编译器(v3.6)进行编译和链接,但使用g++(版本4.9.2)时出现链接错误:u.o:relocationR_X

c++ - 为什么 leveldb 中的 table 和 tablebuilder 使用 struct rep?

最近看了leveldb的源码,对table和table_builder源码中的repstruct搞混了。因为我们可以直接将成员变量直接存储在类Table和类TableBuilder中。但是为什么作者做了一个structRep,把成员变量存放在structRep中。我可以想出一个原因,因为table和table_builder会暴露给用户,所以我们想隐藏实现。这样对吗?还是我错过了其他一些想法,或者是某种设计模式?谢谢 最佳答案 这是从table.h中提取的代码片段,来自table_builder.h的代码片段会显示类似的设计clas