草庐IT

BIT_SIZE

全部标签

c++ - 保证 std::container::size_type 是一个 std::size_t

正在关注thisquestion,我决定使用std::size_t作为size_type对于每个容器,出于明显的可读性原因。我知道这在理论上是可能的std::container::size_type不是std::size_t,但我认为我当前和future的配置并非如此。但是,为了避免恶意错误,我在使用它们时会检查类型是否相同。例如:BOOST_STATIC_ASSERT(boost::is_same::size_type,std::size_t>::value);std::vectorx;/*fillx*/for(std::size_ti=0;i代码的另一个地方,我使用了一个std::

c++ - 如何修复 "Invalid read of size 8 - 40 bytes inside a block of size 64 free' d"

m_PhyToBtMap中SPacket中的shared_ptr似乎导致“大小为8的无效读取-大小为64的block内的40字节已释放”。注意:在valgrind(下面的日志)发出此错误消息之前,它运行了将近22小时,包含数百万条消息,但我也在E​​raseAcknowledgedPackets(下面)中遇到SIGSEGV崩溃,并怀疑这是原因。我正在使用Boost1.63,因为交叉编译器不支持shared_ptr。SendMessageToBt(大小为8的无效读取)和EraseAcknowledgedPackets(大小为64的block内的40个字节已释放)在valgrind日志中被

c++ - gdb 错误消息 : DW_OP_reg, DW_OP_piece 和 DW_OP_bit_piece

我正在调试别人的Qt程序并遇到以下我不理解的错误消息:DWARF-2expressionerror:DW_OP_regoperationsmustbeusedeitheraloneorinconjuctionwithDW_OP_pieceorDW_OP_bit_piece.我不确定这意味着什么,Google也帮不上什么忙。这里是上下文-sLocation是一个QString,它在几行之前声明过。然而,它是从内联函数创建的,所以我不确定它的值(value),并试图在附加到之前进行检查:(gdb)printqstringsuffix(QString)0xffffbd80:"sorted"(

c++ - 与size_t比较,返回int?

我正在编写“如何像计算机科学家一样用C++思考”中的一些代码示例,而这个示例是关于处理扑克牌类型的对象和牌组的。我正面临这种情况:intCard::find(conststd::vector&deck)const{size_tdeckSize=deck.size();for(size_ti=0;i我不能像文中那样在VisualStudio2010中的C++中的vector上使用“.length()”,而是不得不使用.size(),它返回(我相信)std::size_type。我想我可以使用size_t并摆脱它以避免在不同体系结构上出现问题,正如我一直在阅读的那样,但我想知道我是否返回i

c++ - 快速整数矩阵乘法与 bit-twiddling hacks

我问是否有可能显着改进整数矩阵乘法bitwiseoperations.矩阵很小,元素是小的非负整数(小意味着最多20)。为了让我们集中注意力,让我们非常具体,假设我有两个3x3矩阵,整数项为0以下简单的C++实现执行了一百万次执行大约1秒,用linuxtime测量。#includeintmain(){//Randomnumbergeneratorstd::random_devicerd;std::mt19937eng(rd());std::uniform_int_distributiondistr(0,15);intA[3][3];intB[3][3];intC[3][3];for(i

c++ - 如何在 CentOS 7.3 64bit 上安装 boost 库?

我需要在CentOS上构建一个使用Boost库的C++项目。我试过这个:yuminstallboost-devel但是我遇到了依赖错误并且没有安装Boost:-->ProcessingDependency:libicuuc.so.42()(64bit)forpackage:libboost_regex1_59_0-1.59.0-1.x86_64-->ProcessingDependency:libicui18n.so.42()(64bit)forpackage:libboost_regex1_59_0-1.59.0-1.x86_64-->ProcessingDependency:lib

c++ - 在 MacOSX 上,使用 g++,std::vector .size() 线程安全吗?

我有一个在两个线程中共享的std::vector。他们都调用了vec->size();这可能是竞争条件的来源吗?我希望不会,因为vec->size()是常量。谢谢! 最佳答案 如果你正在调用ONLYvec->size()你是安全的。但这在某种程度上令人难以置信。一旦您调用任何更改方法(例如push_back),竞争就会导致获得错误的大小。 关于c++-在MacOSX上,使用g++,std::vector.size()线程安全吗?,我们在StackOverflow上找到一个类似的问题:

c++ - 将 SSE 翻译成 Neon : How to pack and then extract 32bit result

我必须将以下指令从SSE翻译成Neonuint32_ta=_mm_cvtsi128_si32(_mm_shuffle_epi8(a,SHUFFLE_MASK));地点:staticconst__m128iSHUFFLE_MASK=_mm_setr_epi8(3,7,11,15,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1);所以基本上我必须从寄存器中取出第4、8、12和16个字节并将其放入uint32_t。看起来像一个打包指令(在SSE中我似乎记得我使用了shuffle因为它比打包节省了一个指令,thisexample显示了打包指令的使用)。这个操作在Neon

C++ 异常 :Throwing Arrays and getting array size in catch

普通函数(例如printArray)采用数组及其大小(2个参数)来打印数组元素。如何使用异常来做同样的事情?更确切地说,如何将数组大小传递给catch处理程序?(假设我没有在try-catch之外声明的constintSIZE)例如。//voidprintArray(int*foo,intsize);intfoo[]={16,2,77,40,12071};//printArray(foo,5);//OK,functioncallusingarrayacceptssize=5try{//dosomethingthrowfoo;}catch(int*pa){//Ihavetogetarra

C++ 套接字 : size of the structure addrinfo

我正在将eclipse与cygwin结合使用。该应用程序是64位的。在cygwin中,结构定义为:structaddrinfo{intai_flags;/*inputflags*/intai_family;/*addressfamilyofsocket*/intai_socktype;/*sockettype*/intai_protocol;/*ai_protocol*/socklen_tai_addrlen;/*lengthofsocketaddress*/char*ai_canonname;/*canonicalnameofservicelocation*/structsockad