草庐IT

zero-size

全部标签

C++11 auto 和 size_type

鉴于auto的以下用法:std::vectorv;for(autoi=0;i对于C++来说,推导i将是理想的选择作为std::vector::size_type,但如果它只查看i的初始化程序,它会看到一个整数。i的推导类型是什么?在这种情况下?这是auto的适当用法吗?? 最佳答案 使用decltype而不是auto来声明i。for(decltype(v.size())i=0;i更好的是,如@MarkB的回答所示,使用迭代器迭代vector。 关于C++11auto和size_type,

c++ - 将 size() 用于 for 构造中的第二个表达式总是不好的吗?

在下面的示例中,我是否应该期望每次循环时都会调用values.size()?在这种情况下,引入一个临时的vectorSize变量可能是有意义的。或者现代编译器是否应该能够通过识别vector大小不能改变来优化调用。doublesumVector(conststd::vector&values){doublesum=0.0;for(size_tii=0;ii请注意,我不关心是否有更有效的方法来对vector的内容求和,这个问题只是关于在for结构中使用size()。 最佳答案 这是一种明确的方法-size()只被调用一次。for(si

c++ - "The Rule of Zero"是否也适用于具有虚方法的类?

我找到了TheruleofZero正如在PeterSommerladsSlides中也提到的那样(第32页)非常引人注目。虽然,我似乎记得有一个严格的规则,必须定义析构函数virtual,如果类有虚拟成员并且实际上是派生的。structBase{virtualvoiddrawYourself();virtual~Base(){}};structDerived:publicBase{virtualvoiddrawYourself();};析构函数的主体甚至可以是空的(它只需要vtbl中的条目)。我好像记得用hierarchy的时候intmain(){Base*obj=newDerived

c++ - size_t 参数新运算符

我有一点想不通新运算符重载。假设,我有一个类MyClass但MyClass.hMyClass.cpp和main.cpp文件是这样的;//MyClass.hclassMyClass{public://Somememberfunctionsvoid*operatornew(size_tsize);voidoperatordelete(void*ptr);//...};//MyClass.cppvoid*MyClass::operatornew(size_tsize){returnmalloc(size);}voidMyClass::operatordelete(void*ptr){free

c++ - std::string 实现是否符合 's.c_str() + s.size()' 不一定与 '&s[s.size()]' 相同?

§21.4.5[string.access]const_referenceoperator[](size_typepos)const;referenceoperator[](size_typepos);Returns:*(begin()+pos)ifpos.Otherwise,returnsareferencetoanobjectoftypecharTwithvaluecharT(),wheremodifyingtheobjectleadstoundefinedbehavior.至少对我来说,第二部分意味着这个“charT类型的对象”可能位于存储在std::string中的序列之外。目

c++ - 捕获最后一个 WM_SIZE

当我调整窗口大小时,我想告诉程序的另一部分我的窗口已更改大小。我在MSDN上阅读那:WMSIZE消息WMSIZE消息在窗口大小更改后发送到窗口。但是,即使在拖动时我也会收到WM_SIZE。我注意到在调整窗口大小时还会发送一条WM_SIZING消息。目前我看不出WM_SIZE和WM_SIZING之间的区别。有什么方法可以捕获最后一个WM_SIZE消息,而不是用调整大小消息“垃圾邮件”我的程序? 最佳答案 当您开始拖动窗口时,系统会进入模式移动/调整大小循环;在拖动操作完成之前,它不会返回到您自己的消息循环。您仍然得到WM_SIZE,因

c++ - C++中size_t的性能

我翻译了代码here如下所示转换为C++#includeusingnamespacestd;intt=20;boolis_evenly_divisible(constinta,constintb){for(inti=2;i在MacOSX10.8.4上的编译器g++4.8.1上使用-O3标志,我得到时间0.568s用户时间。现在,如果我将函数is_evenly_divisible中第1行的计数器i更改为size_t,时间会突然跳到1.588s。即使我将所有变量都更改为size_t,这种情况仍然存在,时间增加到1.646s这是怎么回事?size_t不应该提高性能而不是降低性能,因为它是比i

C++ size_t 或 ptrdiff_t

如果您有以下代码,其中p是一个指针:p=p+strlen(p)+size_t(1);由于strlen()和size_t都是size_t,我应该将代码转换为ptrdiff_t吗?p=p+(ptrdiff_t)(strlen(p)+size_t(1));如果是,为什么?谢谢,格雷格 最佳答案 std::ptrdiff_t已签署。std::size_t未签名。如果p可能有负长度,则将strlen(p)转换为ptrdiff_t是有意义的,这是不可能的。但是,如果p足够大(例如,在大多数32位平台上大于2,147,483,647字节),则该转

c++ -::operator new(size_t) 是否使用 malloc()?

::operatornew(size_t)是在内部调用malloc(),还是直接使用系统调用/操作系统特定的库调用?C++标准怎么说?在thisanswer它说:malloc()isguaranteedtoreturnanaddressalignedforanystandardtype.::operatornew(n)isonlyguaranteedtoreturnanaddressalignedforanystandardtypenolargerthann,andifTisn'tacharactertypethennewT[n]isonlyrequiredtoreturnanaddr

c++ - 如何 "zero"OpenCV 中图像蒙版部分内的所有内容

如果我有一个图像(IplImage8位)和一个二进制掩码(它也是一个相同大小的8位IplImage,其中每个像素的值为0或255),我如何使每个图像中与掩码中值为零的像素对应的像素具有零值,并且图像中与掩码中具有任何其他值(即255)的像素对应的每个像素具有相同的值在原始图像中?换句话说,任何“在mask区域内”的东西都将保持其原始值,而mask区域外的任何东西都将变为零。 最佳答案 最简单的方法,使用'Matimg'(要屏蔽的图像,输入)和'Matmasked'(屏蔽的图像,输出):img.copyTo(masked,mask)其