草庐IT

test_sizeof

全部标签

c++ - 为什么 virtual void test()=00 有效但 virtual void test()=+0 和 virtual void test()=-0 无效?

我搜索了一些关于虚函数声明的帖子,相信=0在virtualvoidtest()=0;是固定句法所以virtualvoidtest()=NULL;virtualvoidtest()=false;virtualvoidtest()=1-1;virtualvoidtest()=0.0;和其他声明应该是无效的。但是我发现了virtualvoidtest()=00;virtualvoidtest()=000;virtualvoidtest()=0000;还能编译,为什么?还有,我觉得整数+0和-0其实和0一样(不知道对不对),就像00其实就是0一样,为什么virtualvoidtest()=+0

c++ - 为什么 sizeof(this - id) 返回 8?

我的代码中有一个非常愚蠢的拼写错误...is.read((char*)&this->id,sizeof(this-id));在this-之后缺少>字符有趣的是sizeof(this-id)返回了8!我的想法是...因为this是一个指针,对this做减法将导致另一个指针被id的值关闭,它可以是任何东西取决于id的值。还有...在64位系统上,指针通常是8个字节!我说的对吗?还是遗漏了什么?下面是我的类(class)。classIndexItem:publicSerializable{public:IndexItem(uint32_tid,std::streampospos):id(id

c++ - C++ 与 D 中的 sizeof 运算符和对齐

考虑以下程序:#includeclassT{charc;inti;};intmain(){std::cout由于对齐,它给出了预期的输出8。C++编译器添加3个字节的填充。但是如果我用D语言做同样的事情,它会给我完全出乎意料的输出。(参见现场演示here。)importstd.stdio;classT{charc;inti;}intmain(){writefln("sizeofTis%d",T.sizeof);writefln("sizeofcharis%d",char.sizeof);writefln("sizeofintis%d",int.sizeof);return0;}我得到的

c++ - 菱形多态继承 : sizeof Most derived Class

我知道菱形继承会导致歧义,可以通过virtualBaseClasses使用继承来避免,问题不在于此。当类是多态时,问题是关于菱形层次结构中最派生类的大小。这是示例代码和示例输出:#includeusingnamespacestd;classBase{public:virtualvoiddoSomething(){}};classDerived1:publicvirtualBase{public:virtualvoiddoSomething(){}};classDerived2:publicvirtualBase{public:virtualvoiddoSomething(){}};cl

c++ - gtest,对 'testing::Test::~Test()' 的 undefined reference ,testing::Test::Test()

我使用apt-getinstalllibgtest-dev安装了gtest我正在尝试检查它是否有效。所以我在eclipse中编写了简单的测试代码。但是有错误,undefinedreferenceto'testing::Test::~Test()'undefinedreferenceto'testing::Test::Test()'相反,如果我将ATest类的继承更改为protected,错误就会消失,但是出现其他错误testing::Testisinaccessiblebaseof'ATest_AAA_Test'怎么了?#include#includeclassA{public:int

c++ - sizeof 运算符在运行时发生变化?

这个问题在这里已经有了答案:Howsizeof(array)worksatruntime?(6个答案)关闭8年前。sizeof运算符是一个编译时运算符,但在下面的程序中它会在运行时发生变化。#includevoidfunc(inti){inta[i];printf("%d\n",sizeof(a));}main(){inti=0;while(i内存将在运行时分配。编译器如何计算没有结构填充的结构大小?

c++ - 错误:使用已删除的函数'test::test (const test&) C++ 结合 vector

我有一个我不明白的问题。我有一个生成线程的类。一切都好。我制作了一个新对象-一切正常。如果我将这些存储在一个vector中以迭代我的代码将无法编译。我使用g++4.9i686。我制作了以下简短程序,它完全模拟了问题,因为真实代码相当广泛。如果有人可以澄清或给我一个对我的宠物项目非常有用的解决方案,因为我坚持这个。代码如下:#include#include#include#includeclasstest{public:test();voidsetstring(std::strings);~test(){}voidrunThread(){m_thread=std::thread(&tes

c++ - 为什么 sizeof(Base) 与 sizeof(Derived) 没有区别

我觉得sizeof(Base)应该是12,为什么是16?没有虚函数,我得到4和8。classBase{public:inti;virtualvoidPrint(){cout预期结果:12,16实际结果:16,16 最佳答案 whysizeof(Base)isnotdifferentofsizeof(Derived)因为编译器引入了对齐。这是架构相关的,但为了简单起见,我假设我们指的是64位架构。Scenario64bit/Clang8.0.类型的对齐Base是8字节数:alignOfBase():#@alignOfBase()mov

c++ - 确定升压变体中的最大 sizeof()

给定:boost::variant在编译时计算如下:max(sizeof(T1),sizeof(T2),sizeof(T3),...,sizeof(TN))我不知道如何解决这个问题,但是this答案阐明了我如何开始。使用该答案中的代码和两种类型,T1和T2,我可以在源文件中使用以下代码来获取较大对象的大小:size_tlargestSize=sizeof(largest::type);这正是我想要做的,但我需要最大的模板来处理两个以上的类——具体来说,它需要检查存储在中的所有类型boost::variant对象。我知道boost::variant有一个typestypedef,它定义了

c++ - (void) sizeof (0[array]) 是什么意思?

我遇到了以下代码,它返回C样式数组的大小。templateintGetArraySize(Type(&array)[N]){(void)sizeof(0[array]);returnN;}模板部分似乎已经在thisquestion中解释过了。.但是,我仍然不明白sizeof行的用途是什么。有任何想法吗?有人建议这是为了避免未使用的变量警告,但可以使用更简单的#pragma,对吧?另外,这段代码在任何情况下都有效吗?没有任何限制吗? 最佳答案 我认为该行的目的是静默未使用的变量警告。更简单的方法是省略参数名称templateintGe