草庐IT

c++ - 为什么 sizeof 给我这个结果?

我有这个代码structStudent{charname[48];floatgrade;intmarks[10,5];chargender;};Students;现在我必须得到s的大小所以我加了printf("%d",sizeof(s));现在当我点击编译时,显示的结果是256这是错误的,因为它应该是253因为大小字符名称[48];---->48和float等级;----->4和整数标记[10,5];------>200和字符性别;------>1所以48+4+200+1=253那为什么它告诉我256?================================这部分是我看到你的答

c++ - 确定结构成员大小的常用 C/C++ 宏是什么?

在C/C++中,如何确定结构成员变量的大小而不需要定义该结构类型的虚拟变量?这是一个错误的示例,但显示了意图:typedefstructmyStruct{intx[10];inty;}myStruct_t;constsize_tsizeof_MyStruct_x=sizeof(myStruct_t.x);//error作为引用,如果您首先定义一个虚拟变量,这应该是如何找到“x”的大小:myStruct_tdummyStructVar;constsize_tsizeof_MyStruct_x=sizeof(dummyStructVar.x);但是,我希望避免为了获取“x”的大小而必须创建

C++ 在预处理器 #if 中对 sizeof() 比较抛出编译错误

我有这个编译时没有出现来自visualstudio的错误“fatalerrorC1017:无效整数常量表达式”。我该怎么做?templateA*Create(){#ifsizeof(B)>sizeof(A)#errorsizeof(B)>sizeof(A)!#endif...} 最佳答案 预处理器不理解sizeof()(或数据类型、标识符、模板或类定义,它需要理解所有这些东西才能实现sizeof)。您正在寻找的是静态断言(由编译器强制执行,它理解所有这些事情)。我用Boost.StaticAssert为此:templateA*Cre

c++ - 获取 std::array 的底层数组的内存大小的最简单方法?

这是获取std::array::data()返回内容的内存大小的最简单/最短方法吗?arr.size()*sizeof(arr.value_type)编辑:我的问题不准确。“内存中的大小”是指数组中包含的所有元素(本身)的大小,例如它们是指向结构的指针,我只想要指针的大小,而不是指向的结构。我也不想包括std::arr实现的任何可能开销的大小。只是数组元素。有些人建议使用sizeof(arr)。这个:Whatisthesizeofstd::array?不同意。虽然它似乎可以在我的机器上工作,但我想知道标准保证是什么。 最佳答案 您可

c++ - 如何确定平台上的最大指针大小?

在(C和)C++中,指向不同类型的指针don'tnecessarilyhavethesamesize.我本来希望void*一定是最大的,但似乎连这实际上都不能保证。我的问题:如何确定我的(编译目标)平台上指针的最大大小是多少?注意:我的意思是任何指针,包括指向类成员函数的指针;您可以通过&获得的东西运算符(operator)。我不是指“通俗地”称为指针的实体,即不是unique_ptr的或shared_ptr之类的。 最佳答案 有3种不同类型的指针,它们可以有不同的大小:指向对象的指针函数指针成员函数指针一个void*根据C++17

c++ - 检测并报告 typedef 错误……这是在做什么?

我正在阅读有关通过使用固定宽度整数使代码更具可移植性的内容。我找到了this帮助解释事情的文章,最后它建议使用这个匿名union来检测和报告typedef错误:staticunion{charint8_t_incorrect[sizeof(int8_t)==1];charuint8_t_incorrect[sizeof(uint8_t)==1];charint16_t_incorrect[sizeof(int16_t)==2];charuint16_t_incorrect[sizeof(uint16_t)==2];charint32_t_incorrect[sizeof(int32_t

c++ - 传入 A::operator new() 的大小是否总是等于 sizeof(A)?

structAfinal{inta;void*operatornew(size_tsize){////Issizealwaysequaltosizeof(A)here?//return::operatornew(size);}voidoperatordelete(void*ptr){::operatordelete(ptr);}};intmain(){for(autoi=0;i我的问题也嵌入了代码中。C++标准是否保证传入A::operatornew()的大小始终相同?更新:在这里,只考虑A是最终类。 最佳答案 引自C++11标准,

c++ - Qt中是否有签名的 `sizeof`替代品

Qt容器的大小返回(有符号)int。我们知道在Qt中,更多的是使用int而不是无符号类型size_t以便在不需要转换的情况下进行算术运算。参见WhydoesQtuseasignedinttypeforitscontainerclasses&WhyQVector.size()returnsint由于语言关键字sizeof返回size_t类型,是否有Qt替代方案? 最佳答案 您可以制作自己的安全版本:templateconstexprintsafeIntCast(){static_assert(s::max(),"Typetoolarg

c++ - CUDA 设备到设备传输昂贵

我已经编写了一些代码来尝试交换二维矩阵的象限以用于FFT目的,该矩阵存储在平面数组中。intleftover=W-dcW;T*temp;T*topHalf;cudaMalloc((void**)&temp,dcW*sizeof(T));//swapeveryrow,leftandrightfor(inti=0;i请注意,此代码采用设备指针,并进行DeviceToDevice传输。为什么这看起来运行得这么慢?这可以以某种方式优化吗?与使用常规memcpy的主机上的相同操作相比,我对这个进行了计时,速度大约慢了2倍。有什么想法吗? 最佳答案

c++ - 为什么 stdarg.h 有一个宏 « __va_size »?

我正在寻找一些关于宏的代码,我找到了这样的代码,用于宏«va_start»:#define__va_argsiz(t)\(((sizeof(t)+sizeof(int)-1)/sizeof(int))*sizeof(int))#defineva_start(ap,pN)\((ap)=((va_list)(&pN)+__va_argsiz(pN)))我想知道«__va_argsiz»函数的目标到底是什么。是对齐限制吗?谢谢! 最佳答案 C中的对齐和默认类型提升规则。 关于c++-为什么st