草庐IT

tmp_pack

全部标签

c++ - 关于 __attribute__((__packed__)) 的 c++ 编译错误还有哪些其他方法?

当我编译以下代码时:#include#includestructTupleHeader{timevaltuple_stime;//34..37}__attribute__((__packed__));voidset_value(timeval&stime){}intmain(){TupleHeadertuple;set_value(tuple.tuple_stime);return0;}我得到了g++-3.4.2下的错误和g++-4.8.3:attribute-1.cc:Infunction`intmain()':attribute-1.cc:13:error:cannotbindpa

c++ - clang compaining about __attribute__((packed)) 即使结构需要打包

我有一个结构,需要打包(不打包大小为20个字节,但我需要16个才能读/写它)。当我添加packed属性时,我得到了结构的所有成员的error:packedattributeisunnecessaryfor警告。当使用pragma消除错误时,代码可以正常编译并且结构的大小为16,但是如果我删除pragma,它就会失败(因为我使用的是-Werror)。clang只是错误地发出了这个警告还是我做错了什么?#includetypedefstruct__attribute__((packed)){uint16_twFormatTag;uint16_tnChannels;uint32_tnSamp

c++ - 如何访问一片 packed_bits<> 作为 std::bitset<>?

我正在尝试实现packed_bits使用可变参数模板和std::bitset的类.特别是,我在编写get时遇到了问题返回对成员m_bits子集的引用的函数其中包含所有打包位。该功能应类似于std::get对于std::tuple.它应该作为一个引用叠加层,这样我就可以操作packed_bits的一个子集。.例如,usingmy_bits=packed_bits;my_bitsb;std::bitset&s0=get(b);std::bitset&s1=get(b);std::bitset&s2=get(b);更新下面是根据Yakk'srecommendationsbelow重写的代码.

c++ - 结构大小和内存布局取决于#pragma pack

考虑以下在VC++2010中编译的程序:#pragmapack(push,1)//1,2,4,8structstr_test{unsignedintn;unsignedshorts;unsignedcharb[4];};#pragmapack(pop)intmain(){str_teststr;str.n=0x01020304;str.s=0xa1a2;str.b[0]=0xf0;str.b[1]=0xf1;str.b[2]=0xf2;str.b[3]=0xf3;unsignedchar*p=(unsignedchar*)&str;std::cout我在return0;行上设置断点并在

c++ - CUDA 内核 "Only a single pack parameter is allowed"解决方法?

关于可变全局函数模板的CUDA7标准指出"onlyasinglepackparameterisallowed."有没有优雅的解决方法?我希望能够做类似的事情:templatevoidRecursiveFunct(){}templatevoidRecursiveFunct(Tt,Args...args){t.templatecall();RecursiveFunct(args...);}我想我可以在传递它们之前将我的整数包包装成某种东西,但是否可以通过一种对该代码的调用者透明的方式来做到这一点? 最佳答案 不确定是否理解您的确切限制,

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++ - `pragma pack(push, 1)` 在 GCC 4.4.7 中崩溃。可能的编译器错误?

我遇到了一个让我难过的错误。我已将其缩小为GCC(特别是RHELLinux,GCCv.4.4.7)中的pragmapack命令的问题,可以在下面显示的小示例案例中重新创建该问题。看起来GCC在这种情况下计算了错误的偏移量,这将表现为循环内的崩溃。删除pragmapack也可以消除错误-但在实际应用程序中,这将导致使用许多额外的千兆字节内存,这是不可取的。在下面的示例中,您需要在启用优化(O3)的情况下进行编译才能体验失败。我还在结构中提供了一个示例项(cMagic),可以将其删除,这将更改结构对齐方式并防止错误触发。我查看了生成的程序集,认为这可能是一个编译器错误。我还缺少其他东西吗?

c++ - mpirun 不工作并要求将 TMPDIR 变量更改为/tmp

我编译了下一段代码:#include#includeintmain(intargc,char*argv[]){intrank,size,len;charhost[MPI_MAX_PROCESSOR_NAME];MPI_Init(&argc,&argv);MPI_Finalize();return0;}我是这样做的:mpic++-otesttest.cpp然后我尝试运行文件:mpirun-np2test但是错误发生了:PMIx检测到一个临时目录名在对于Unix域套接字来说太长的路径中:临时目录:/var/folders/12/k2b2579s1yz2cfl8ppb1c6m80000gn/

c++ - 可变参数模板 : Pass parameter pack without expansion

旧的Cstdio工具提供了一种使用vprintf工具传递可变参数集的方法。是否有类似的方式来传递C++0x可变模板参数包而不扩展它?如果您有一个采用可变参数模板参数包的派生类构造函数,并且需要简单地将其传递给基类构造函数,而不是将其解包,这可能会很有用。例如:templateBase::Base(constT&v,constArgs&...args){/*...expandargshere....*/}templateDerived::Derived(constT&v,constArgs&...args):Base(v,args){/*...don'texpandargs...*/}我

c++ - 使用 TMP 预计算值何时真正有用?

“EffectiveC++”中的ScottMeyers指出了执行以下操作的能力:编译器中的矩阵运算作为在模板类/函数中实现某些算法的原因。但是这些函数不能对在运行时确定的参数进行操作,显然——它们只适用于写入程序或最多作为参数提供给编译器的数字。程序编译后,每次运行时都会使用相同的输出值。在那种情况下,为什么不使用常规(非模板)程序计算该值,并在必要时将其写入原始程序呢?它不是更快来计算例如1000点。编译器中的fft肯定比常规程序要好。我能想到的最好办法是,如果您需要为不同的客户端编译不同版本的程序,那么TMP可能会为您节省一些时间。但这种需求真的会出现吗?