草庐IT

attribute_short

全部标签

c++ - 如何从一个long long int中提取四个unsigned short int?

假设我有一个longlongint并想从它的位中提取出四个unsignedshortint。特定的顺序在这里并不重要。我通常知道我需要移位并截断到unsignedshortint的大小。但我想我可能在某个地方犯了一些奇怪的错误,所以我问。 最佳答案 #include#includeunionui64{uint64_tone;uint16_tfour[4];};intmain(){unionui64number={0x123456789abcdef0};printf("%x%x%x%x\n",number.four[0],number

c++ - 在 g++ 中使用 __attribute__ 的不平衡括号

今天我在前段时间开发的一个项目上尝试了clang。当它遇到编译错误时我很惊讶,因为我已经使用g++成功编译了我的项目。这个简短的片段重现了遇到错误的行:intmain(){__attribute__((aligned(16))chararr[5];}产生此错误的原因:test.cpp:2:32:error:expected')'__attribute__((aligned(16))chararr[5];^)如您所见,有一个不平衡的括号。有三个“(”和两个“)”。这显然看起来应该会产生编译错误。这是该关键字的有效用法吗?我似乎无法在thedocumentation上找到任何内容这表明它是

c++ - 我什么时候使用 "__attribute__((nonnull))"与 "not_null<T*>"?

我习惯于使用__attribute__((nonnull))表达不应为空的指针时。voidf(int*ptr)__attribute__((nonnull));intmain(){int*ptr=newint(1);f(ptr);}voidf(int*ptr){/*impl*/}但是,对于GSL,还有not_null包装类型。voidfunction1(gsl::not_nulln);voidf(gsl::not_nulln);intmain(){int*ptr=newint(1);f(ptr);}voidf(gsl::not_nulln){/*impl*/}假设语言设施支持GSL版本

c++ - 将 unsigned char 转换为 int 和 short

我是新手,所以我首先要说的是,当我查看一些代码时,我意识到这个函数对我来说一点意义都没有。如您所见,此特定函数使用按位运算符将4个无符号char元素转换为整数。//使用小端形式将一个四字符数组转换为一个整数inttoInt(constchar*bytes){return(int)(((unsignedchar)bytes[3]我已经知道按位运算符如何使用以及char如何使用1个字节而int如何使用4个字节。为什么将char位向左移动24位而不是直接将其显式转换为int并将其转换为int?为什么这个函数需要按位运算符?这个函数超出了我的理解范围,请解释这段代码及其工作原理,或者至少给我一

【ARM 嵌入式 编译系列 2.4 -- 编译参数-Wl,--gc-sections | -wsuggest-attribute=pure | -wreal-q-constant |】

请阅读【嵌入式开发学习必备专栏之ARMGCC编译专栏】文章目录概述编译参数详细介绍-Wl选项例子:--gc-sections``--gc-sections例子:-Wshadow例子:-Wlogical-op例子:-Waggregate-return例子:-Wfloat-equal例子:-Wconversion例子:-Wpointer-arith例子:概述在使用GCC(GNUCompilerCollection)进行编译时,可以通过不同的编译参数(标志)来控制编译行为、优化级别、警告输出等。以下是您列出的一些GCC编译参数的介绍:编译参数详细介绍参数作用–all-warnings与-Wall相同

c++ - 将 __attribute__ 与 typedef 结合使用

如果问题看起来太明显或太简单,我们深表歉意。不幸的是,在经历了一堆线程并用谷歌搜索了typedef加上attribute前缀之后,我仍然无法弄清楚。我在(据说)可移植应用程序中有以下代码片段-#ifdefWIN32#defineMY_PREFIX__declspec(dllexport)#else#defineMY_PREFIX__attribute__((visibility("default")))#endiftypedefMY_PREFIXboolsome_func(void);所以我的问题是-1)typedef到底在做什么?2)代码在VS2008上编译良好,但在G++(gcc-

c++ - [[attributes]] 是 C++11 的新功能吗?

usingC++11attributes提示[[attributes]]是C++11的新内容。我想确认一下:属性是C++11的新特性吗? 最佳答案 是的,属性是2011ISOC++标准中的一个新特性;以前的2003标准中没有指定它们。它们记录在标准的第7.6节[dcl.attr]中。该标准的最新草案是N3376(PDF,4.9MB)。 关于c++-[[attributes]]是C++11的新功能吗?,我们在StackOverflow上找到一个类似的问题: ht

c++ - 让 Howard Hinnant 的 short_alloc(C++11 版本)在 Visual C++ 2015 中编译

我希望能够将自定义分配器与std::vector一起使用,以便将小数据缓冲区(例如,小于1024字节)存储在堆栈上,并且只有较长的vector存储在堆上。作为一个有Fortran背景的人,每次我必须进行堆内存分配以在五行子程序的持续时间内存储六个元素时,这让我感到body疼痛!HowardHinnant发表了他的short_alloc分配器完全符合我的要求,如果我用gcc编译它,它会很好用。但是,在VisualC++中我无法编译它。在VisualC++2013中,部分问题是不受支持的C++11关键字太多,但即使我已将所有这些都#DEFINE掉,我仍然遇到了问题。今天尝试用VisualC

c++ - 自定义支持 __attribute__((format))

GCC和Clang都支持对可变参数函数(如printf)进行编译时检查。这些编译器接受如下语法:externvoiddprintf(intdlevel,constchar*format,...)__attribute__((format(printf,2,3)));/*2=format3=params*/在OSX上,Cocoa框架还使用了NSString的扩展:#defineNS_FORMAT_FUNCTION(F,A)__attribute__((format(__NSString__,F,A)))在我们公司,我们有一个自定义的C++框架,其中包含一堆类,例如BaseString,它

c++ - 有效地将 unsigned short 转换为 char*

什么是将unsignedshort转换为char*(即将25转换为'25')的高效、可移植的方法。我想避免涉及(std::string)字符串之类的事情。在这种情况下,性能很重要,因为这种转换需要快速且经常发生。我正在研究诸如使用sprintf之类的事情,但想探索任何和所有想法。 最佳答案 首先,正确地做事,然后快速地做事——只有在您确定某段代码性能不佳时才进行优化。snprintf()放入缓冲区将执行您想要的操作。这是最快的解决方案吗?一点也不。但它是最简单的之一,足以让您的代码进入工作状态。从那里开始,如果您发现对snprint