草庐IT

vec_bool

全部标签

c++ - 函数 bool isnan( … ) 在 C++ 中的定点实现

我正在用C++进行定点实现,我正在尝试定义“非数字”并支持函数boolisnan(…)如果数字不是数字则返回true,否则返回false。有人能给我一些关于如何定义“非数字”并在我的定点数学实现中实现函数boolisnan(…)的想法吗。我读过有关C++Nan的资料,但我无法获得有关如何手动定义和创建函数nan()以在定点实现中使用它的任何来源或引用。有人可以告诉我如何进行或提供一些引用以进行吗?谢谢更新定点header#ifndef__fixed_point_header_h__#define__fixed_point_header_h__#include#include#endif

c++ - 为什么在成功将 bool 字符串值转换为 bool 值时,istringstream eof 标志没有变为真?

我正在学习如何使用istringstream将存储为字符串的值转换为native类型。当存储为字符串的数字成功转换为int或double时,istringstreameof()函数返回true。当存储为字符串的bool值成功转换为bool时,eof()返回false。造成差异的原因是什么?为什么当似乎没有其他字符需要处理时eof()不返回true?转换为bool值的代码:stringvalue="true";istringstreamconverter(value);boolconvertedValue;if(!(converter>>std::boolalpha>>converted

c++ - __sync_val_compare_and_swap 与 __sync_bool_compare_and_swap

我一直在思考这两个函数的返回值。__sync_bool_compare_and_swap函数的返回值似乎有明显的好处,即我可以用它来判断交换操作是否发生。但是,我看不到__sync_val_compare_and_swap的返回值的良好用途。首先,让我们有一个函数签名供引用(来自GCC文档减去varargs):type__sync_val_compare_and_swap(type*ptr,typeoldvaltypenewval);我看到的问题是__sync_val_compare_and_swap的返回值是*ptr的旧值。准确地说,这是在设置了适当的内存屏障后,此函数的实现所看到的

c++ - "#define bool bool"当我悬停 bool 时说 QtCreator - 我将其跟踪到 boost::asio

我注意到bool在QtCreator中以不同于其他类型的颜色突出显示:只有在包含某些header时才会发生这种情况,最终我将其追踪到.QtCreator的代码检查器似乎无法手动跟踪定义。我使用的boost版本是Boost1.59。这样做有什么目的吗?我真的不介意,但是为同一事物定义任何东西是相当奇怪的,而不是bool. 最佳答案 好吧,我搜索了Boost1.59代码,看看是否可以找到:#defineboolbool或#include但我最终没有找到它们,所以它可能在这些文件中,但很可能在其他地方。Isthereanypurposef

c++ - bool 位字段与逻辑位掩码或位移 - C++

我有一系列需要很多bool字段的类,大约在4-10个之间。我不想为每个bool值使用一个字节。我一直在研究位域结构,例如:structBooleanBitFields{boolb1:1;boolb2:1;boolb3:1;boolb4:1;boolb5:1;boolb6:1;};但在做了一些研究后,我看到很多人说这会导致内存访问效率低下,不值得节省内存。我想知道这种情况的最佳方法是什么。我应该使用位字段,还是使用带位掩码的字符(and'sandors)存储8位?如果第二种解决方案是移位更好还是使用逻辑更好?如果有人可以评论他们会使用什么方法以及为什么它真的能帮助我决定我应该走哪条路。提

c++ - 如何填充 Vec3b 数组

我正在使用C++和OpenCV处理图像。我用一个二维uchar数组编写了代码,我可以在其中读取图像的像素值,使用.at(i,j)以灰度方式使用imread上传图像。.但是我想对彩色图像做同样的事情。因为我知道要访问我现在需要的像素值.at(i,j)[0],.at(i,j)[1]和.at(i,j)[2],我做了一个类似的Vec3b二维数组。但我不知道如何用像素值填充这个数组。它必须是一个二维数组。我试过:array[width][height].val[0]=img.at(i,j)[0]但这没有用。在OpenCV文档或此处均未找到答案。有人有想法吗?我已经包含了一些我的代码。我需要一个数

c++ - "if (var)"使用数字转换而不是 bool 值

为什么if(var)...使用数字转换而不是bool值?我有一个实现两者的类:operatorint(){....}operatorbool(){....}但是如果我使用:if(my_class_var)....;然后使用int转换而不是boolean?!!?!编辑:正如versedmarald所说,这是正确的。我发现了不同之处。我实际上使用的是:operatorint(){....}operatorbool()const{...}还是被迷住了,为什么不一样?gcc版本4.6.2 最佳答案 如果你说的是真的,我认为你的编译器违反了标

c++ - vector<bool> 可以由 int 初始化吗

我想枚举[0,31]的bool表示并将其存储在tries中供以后使用。staticconstintN=5;vectortries(N);for(inti=0;iinitializedbyint?//soIdon'thavetodobitoperationfor(intt=0;t 最佳答案 std::vector不能这样做,但是std::bitset能够。由于vector的大小在您的情况下是恒定的,因此您应该使用std::bitset.只需使用您想要的非负整数值对其进行初始化即可。请注意bitset不提供(或模仿)Container接

c++ - 检查 bool vector (范围)是否等于 1 和 0 的序列

我之前拥有的是一串1和0,我可以简单地检查某个范围是否等于我想要的序列:if(myString.substr(0,4)=="1110")...出于内存原因,我将这个字符串变成了vector,因为vector中的一个bool只占用1位而不是1字节。现在,这里有一个问题。我想做与substr相同的比较.可能没有类似的东西:if(myVector[0]==true&&myVector[1]==true&&...)或vectortmpVector;tmpVector.push_back(true);tmpVector.push_back(true);...if(myVector==tmpVec

c++ - 用位域打包 bools (C++)

我正在尝试使用C++与Ada代码进行交互,因此我正在使用位字段定义一个结构,以便所有数据在两种语言中都位于同一位置。以下内容不完全是我在做什么,但概述了问题。以下也是VS2008中的控制台应用程序,但这不是特别相关。usingnamespaceSystem;intmain(){intarray1[2]={0,0};int*array2=newint[2]();array2[0]=0;array2[1]=0;#pragmapack(1)structtestStruct{//Word0(desired)unsigneda:8;unsignedb:1;boolc:1;unsignedd:21