草庐IT

line_size

全部标签

c++ - 输入参数传递 : is there a size threshold for efficient pass-by-value?

在C++中,当输入参数复制成本低时(例如,int、float等),它通常被传递只需按值。相反,复制起来并不便宜的输入“观察到的”参数(例如std::string)由const&传递。我想知道像POD这样的类型表示具有int坐标的二维vector,例如structVec2i{intX;intY;};在32位MSVC编译器上,它只有8个字节(2*sizeof(int))。您会按值还是按const&传递它?那么Vec2d有double类型的坐标呢?(在MSVC上它将是2*sizeof(double),所以2*8=16字节。)是否有“大小阈值”(例如16字节?)用于放置一行并说:“对于超过X大

c++ - 如何去掉doxygen协作图中的 "size_t"

Doxygen(v1.8.11)创建漂亮的UML协作图。不错,除了被汇集到“size_t”的行弄得乱七八糟。形式上正确,但完全没用。有没有办法防止“size_t”出现在聚合类中? 最佳答案 在您的Doxygen配置文件中将size_t放在EXCLUDE_SYMBOLS下。http://www.doxygen.nl/config.html#cfg_exclude_symbols 关于c++-如何去掉doxygen协作图中的"size_t",我们在StackOverflow上找到一个类似的问

c++ - 在 size_t 中使用负整数是否安全?

我刚刚看到一些像这样的C++代码。它使用一个条件来决定是通过std::vector向前走还是向后走。编译器没有提示,但我认为size_t是未签名的。这很危险吗?vectorv{1,2,3,4,5};boolrev=true;size_tstart,end,di;if(rev){start=v.size()-1;end=-1;di=-1;}else{start=0;end=v.size();di=1;}for(autoi=start;i!=end;i+=di){cout 最佳答案 以这种方式使用无符号整数(并且size_t是无符号的)

c++ - 如何处理 size_t 与 std::size_t?

刚读完:Does"std::size_t"makesenseinC++?我意识到使用::size_t不符合标准(虽然我的编译器支持)当你#include.我想遵守标准,但我不想在前面加上std::我所有的size_t的。那么,更习惯/流行的处理方式是什么:写usingstd::size_t;?包括?仅仅依靠编译器的支持?还有别的吗? 最佳答案 您应该使用using指令指定它。usingstd::size_t;将其添加到每个编译单元的全局范围,或者如果它会在全局范围内造成干扰,则将其添加到本地范围。stddef.h也有效,正如您所指出

c++ - 部分模板特化与不匹配的 `int` 和 `size_t` 不编译

引用以下代码#include#includetemplatestructWot;templatestructWot>{};intmain(){assert(sizeof(Wot>)==1);}这适用于clang但不适用于gcc,当我更改部分特化的类型以在索引序列中接受std::size_t但它有效时。谁是对的?Clang还是gcc?在此处查看实际操作https://wandbox.org/permlink/5YkuimK1pH3aKJT4 最佳答案 gcc是对的。这正是[temp.deduct.type]/18:IfPhasafor

c++ - Bison/柔性 : print erroneous line

我正在使用bison+flex来解析文件。出错时调用yyerror()。如何获取违反规则的行号或字符串,并打印错误信息? 最佳答案 行号很简单:yylineno是行号。在.l文件的顶部指定%optionyylineno。好吧,几乎很容易。Lookahead有时会使行号减一。与其说“Erroroccurredatline#xxx”,不如说错误发生在#xxx行附近。至于剩下的,就看你的了。您将不得不捕获不太有效的语法并调用适当的警告或错误处理程序。有关详细信息,请参见O'Reilly的“flex&bison”一书;它有一整章是关于错误信

c++ - "const T& operator[](size_type i)"中的 const 有什么用?

我在一本书http://www.acceleratedcpp.com/中发现了这个有趣的行-资源-第11章-Vec.h(我是一个std::vector翻版)而且我真的不明白这个版本的运算符有什么用。为什么要定义此运算符的两个版本(常量和非常量)?我什至试过了,在我看来,非常量版本一直被调用......你能解释一下吗?#include#include#include#includeusingnamespacestd;templateclassVec{public:typedefT*iterator;typedefconstT*const_iterator;typedefsize_tsiz

c++ - 使用 -1 作为无符号 (size_t) 类型的标志值

我使用-1作为返回类型为size_t(无符号类型)的函数的标志值。一开始我没有注意到它,特别是因为它没有在我的代码中造成任何错误(我用x==-1来检查它,而不是x有什么微妙的原因我不应该保持原样吗?这什么时候可能会出乎意料?这个常用吗?ptrdiff_t不太常见,需要更长的输入时间,而且它并不是真正合适的类型,因为该函数返回数组的索引。 最佳答案 -1将始终转换为最大无符号值,这是由于4.7Integralconversions部分:Ifthedestinationtypeisunsigned,theresultingvalueis

c++ - GDB 不断产生 "No line xx in file"错误,即使文件中包含以下行

这真的很烦人。我用几个文件得到了这个,但我不明白为什么。这是一个示例源代码。(请不要关心内容,只需复制粘贴并在my_atoi函数的某处设置断点,gdb不允许设置断点)。my_atoi适用于十进制、八进制和十六进制数,将C风格的字符串(表示具有这些基数的数字)转换为整数(不过这只是为了练习。我不会用它,所以别担心).为了正确测试它,请在命令行中输入一个参数。即./my_atoi0x12编译命令如下:g++-g-omy_atoimy_atoi.cpp这是gdb命令:gdb-r--annotate=3my_atoi我为遇到类似错误的另一个文件启用了-r,并且它已修复(虽然我不明白为什么)。但

c++ - 使用 mingw-w64 工具链时,以 Release模式链接的 Regex Boost 库会发出 "duplicate section has different size"警告

在Release模式下链接我的项目时,我收到以下警告:myProject-libs/release/libboost_regex-mt-s-1.50.0.a(cpp_regex_traits.o):duplicatesection`.data$_ZZN5boost16cpp_regex_traitsIcE21get_catalog_name_instEvE6s_name[boost::cpp_regex_traits::get_catalog_name_inst()::s_name]'hasdifferentsize我怀疑原因可能是boost库的编译选项与我在项目中使用的选项不同,但我