草庐IT

c++ - 有什么方法可以设置 8 字节 (x64) 的 C++ 长类型大小?

GCC使用sizeof(long)=8编译程序,而VisualStudio使用sizeof(long)=4。如何在Windowsx64上将sizeof(long)设置为8字节? 最佳答案 long的实际大小isn'tspecifiedtobeanexactnumberofbytes,只有它必须能够表示的值范围。但是,您可以使用固定宽度的整数std::int64_t这与其他固定宽度整数类型一起在中可用。 关于c++-有什么方法可以设置8字节(x64)的C++长类型大小?,我们在StackO

c++ - 理解以下 C++ 代码时遇到问题。 (寻求)

#include#includeclassTest{charname[10];intdata;public:voidgetData(){cin>>name;cin>>data;}voiddisplay(){cout>name;cin>>data;}};intmain(){Testt1,t2,t3,t4;//remove("FileIO.dat");t1.getData();t2.getData();t3.getData();t4.getData();fstreamfp1("FileIO.dat",ios::out|ios::app);fp1.write((char*)&t1,sizeo

c++ - 为什么 g++ 4.8.1 会发出转换警告

当我以这种方式用g++4.8.1(64位)编译下面的代码时:$g++-Wconversion-omainmain.cpp我得到这个结果:main.cpp:Infunction‘intmain()’:main.cpp:12:20:warning:conversionto‘int’from‘longunsignedint’mayalteritsvalue[-Wconversion]inti=sizeof(x)/sizeof(x[0]);^我的期望是编译器应该能够在编译时计算表达式。如果您用普通的c编写类似的程序,gcc的工作就像一个魅力。这应该被认为是g++中的错误(例如clang++没有

c++ - 为什么 (void)sizeof(param) 不是 "using"参数?

我有一个定义如下的宏:#defineUNREF_PARAM_1(a)do{\(void)sizeof(a);\}\while(0)去除编译器警告。在我正在处理的一个新项目中,VS2013突然再次提示未引用的形式参数。奇怪的是,如果我只使用(void)param,它确实有效。有没有人知道为什么它在与(void)sizeof(param)一起使用时不起作用? 最佳答案 因为在sizeof(param)中,param是所谓的未计算的操作数,因此未被odr使用-也就是说,不是在运行时需要。但是,(void)param确实构成了odr-use

c++ - 为什么这个数组的 sizeof() 是非法的?

我有以下数组:staticstd::pairtypemap_[];定义为std::pairtalos::Message::typemap_[8]={{talos::Message::Type::Empty,typeid(int).hash_code()},{talos::Message::Type::Keyboard,typeid(int).hash_code()},...为什么会这样sizeof(typemap_);给出一个编译时错误ErrorC2070'std::pair[]':illegalsizeofoperand即使这样sizeof(typemap_[0]);合法且数组大小固

c++ - sizeof() 的值是由编译器还是链接器决定的?

我正在尝试解决一个C++问题,我的代码的两部分为sizeof()运算符返回了不同的结果。这是我运行的MyClass*foo=newMyClass();intsize=sizeof(*foo)我将这段代码放在项目的两个不同部分,得到了两个不同的结果。一次是2254,另一次是2284。我可以查看内存布局,一个区域将内部成员显示为字节对齐,另一个区域显示为字对齐。我查看了dissasmbly,发现sizeof()值实际上是机器代码的一部分。这会是编译器或链接器中的错误吗?为什么同一个项目的两个部分会以不同的方式查看同一个类?编辑:让我提供一个更清楚的例子,我刚刚运行它来证明这不是ODR违规。

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++ - 为什么 uint8_t + uint8_t 会产生一个 int?

这个问题在这里已经有了答案:Additionoftwocharsproducesint(3个答案)关闭3年前。我注意到,对于8位变量的简单操作,变量在操作完成之前转换为32位int,然后再转换回8位变量。例如,这个C++程序:#include#includeintmain(void){uint8_ta=1;uint8_tb=2;std::cout产生以下输出:sizeof(a)=1sizeof(b)=1sizeof(a+b)=4所以我们可以理解发生的事情是:uint8_tc=(uint8_t)((int)(a)+(int)(b));显然,它似乎在this中所说的C规范中。论坛。此外,在

c++ - MSVC : what compiler switches affect the size of structs?

我有两个单独编译的DLL,一个是从VisualStudio2008编译的,一个是从matlab编译的mex文件。两个DLL都包含一个头文件。当我在一个DLL中采用sizeof()结构时,它返回48,而在另一个DLL中它返回64。我检查了/Zp开关,在两个编译中它都设置为/Zp8。还有哪些其他编译器开关可能会影响结构的大小?该结构是一个简单的POCO,没有继承,也没有虚函数。编辑结构看起来像这样:classLIBSPECSGeometry{public:std::vectorm_i;uintN;uintn_im,n_s;};在调试中,sizeof()在两种情况下都返回56,在发行版中,在