草庐IT

some_attribute

全部标签

c++ - boost ASIO async_read_some

我在实现一个简单的TCP服务器时遇到了困难。以下代码摘自boost::asioexamples,准确地说是“Http服务器1”。voidconnection::start(){socket_.async_read_some(boost::asio::buffer(buffer_),boost::bind(&connection::handle_read,shared_from_this(),boost::asio::placeholders::error,boost::asio::placeholders::bytes_transferred));}voidconnection::ha

c++ - Arduino:命令 Serial.print ("some string text") 是否占用 SRAM?

我有一个相当大的Arduino项目(在eclipse中)使用Serial.print("somestringtext")命令进行大量调试消息,以便我可以一路调试。我注意到的一件事是我达到了项目中可以拥有的这些数量的限制。如果我放太多,程序会在非常奇怪的地方停止。即:通常在我最新添加的打印命令应该执行之前很久。目前我的项目.hex文件大约有20k。ArduinoUno限制在30kb左右,对吗?所以它不应该太大。所以我觉得实际的问题可能是这些串行命令正在填满我的sram。这只是2kb。我正在使用很多库。命令Serial.print("somestringtext")是否占用SRAM?gcc

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++ - 当 std::stringstream 使用 ("some content"构造时,tellg() 的预期行为是什么,std::ios::in|std::ios::ate)?

我有以下令我惊讶的代码(使用libstdc++4.8)...#include#include#includeusingnamespacestd;intmain(){std::strings("somecontent");std::stringstreamss(s,std::ios::in|std::ios::ate);std::istream&file=ss;//ss.clear();Makesnodifference...std::cout...具有以下输出。tellg()pos:0此行为与使用std::ifstream(std::ios::ate)时不同。此行为是否正确/符合预期?

【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++ - Boost::asio async_write_some 与 async_send

我刚才才注意到boost::asio中的async_write_some和async_send(第二次重载)函数是完全一样的:async_write_some定义:...templateBOOST_ASIO_INITFN_RESULT_TYPE(WriteHandler,void(boost::system::error_code,std::size_t))async_write_some(constConstBufferSequence&buffers,BOOST_ASIO_MOVE_ARG(WriteHandler)handler){//Ifyougetanerroronthefo

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,它