草庐IT

c++ - std::bad_alloc 不进入交换空间

我试图理解为什么当我似乎有足够的(虚拟?)可用内存时我会收到std::bad_alloc异常。本质上,我有一个素数生成器(Eratosthenes筛法(尚未分段)),我在其中为指示器数组更新bool值,然后为我在命令行指定的范围内找到的素数更新整数。我有1GB内存(其中一些会被我的操作系统(ubuntu10.04)占用,并且可能其中一些不可用作堆内存(我在这里错了吗?))和2.8GB交换空间(我相信这是在安装Ubuntu时为我自动设置的)如果我将上限设置为600000000,那么我需要0.6GB的内存用于我的指标数组和大约30000000*4字节(略微高估,因为有26355867个小于

c++ - 'mapped_type' std::map 错误的初始化没有匹配的构造函数

我有一个名为“Card”的类,我试图将它的一些对象存储在std::map中卡片.hpp:classCard{public:enumValueType{NOVALUE,ACE};enumFaceType{NOFACE,CLUBS};Card(constValueType&_value,constFaceType&_face);Card(constCard&_card);private:ValueTypem_value;FaceTypem_face;};以下是我存储和访问它的方式:甲板.hpp:#includeclassCard;classDeck{public:Deck();std::s

c++ - 是否可以推断出 std::insert_iterator 包含的类型?

我有一个需要模板化迭代器类型的函数。它当前取消引用迭代器以检查被迭代的类型。templatevoidfunc(Iteratori){//Inspectthesizeoftheobjectsbeingiteratedconstsize_ttype_size=sizeof(*i);...}我最近发现一些标准迭代器类型,例如std::insert_iterator将*i定义为对i的简单引用.即sizeof(*i)是迭代器本身的大小;与sizeof(i)或sizeof(***i)相同是否有一种通用方法(支持C++03)来确定任何标准迭代器正在迭代的对象的大小或类型?

c++ - 如何验证运行时失败是否是由于生成的线程过多造成的?

我正在使用std::thread和gcc作为我的编译器来实现并行合并,如Cormen'sIntroductiontoAlgorithms中所述。.我想我得到了可以工作的代码。它传递所有不太大的随机种子数组。但是,当我尝试合并两个大数组(每个数组1e6个元素)时,我得到以下终止:terminatecalledwithoutanactiveexceptionterminatecalledrecursivelyterminatecalledrecursively使用gdb没有帮助:它在运行期间会损坏。我很确定由于产生了太多线程而导致运行失败。我该怎么做才能确认此错误是由于生成的std::th

c++ - Boost套接字 - 客户端没有从服务器接收所有字节

我正在使用C++开发应用程序,但在使用boost套接字时遇到了一些困难。服务器发送图像,但并非所有字节都被客户端接收;客户端总是收到比服务器发送的少大约500个字节。下面提供程序运行的相关代码和截图。服务器代码:intsent=boost::asio::write(*socket,response,boost::asio::transfer_all(),error);std::cout客户端代码(我知道如果服务器发送的总字节数能被10000整除,read_some会阻塞;此代码仅用于测试):intlen=0;intcount=0;do{len=socket->read_some(boo

c++ - 如何为集合提供带有迭代器的 const 接口(interface)?

我想创建一个具有如下签名的函数://Setfoundtobeaniteratortothelocationofkeyinmaporend()//ifnotfound.boollookup(constKey&key,conststd::map&map,std::map::const_iterator&found);但我也想在映射和迭代器不是const的情况下调用它,以便我可以修改找到的值:constKeykey;std::mapmap;std::map::iteratorfound;if(lookup(key,map,found)){found->second.modifingNonCo

c++ - 单条件变量是否可以用于双向同步?

是否可以使用单个条件变量进行双向同步(即在不同时间等待同一条件变量的两个不同条件)?我确信在任何时候都不会有超过一个线程等待条件变量。下面的示例代码说明了我的想法:#include#include#include#includestd::condition_variablecondvar;std::mutexmutex;inti;voideven(){while(ilock(mutex);if(i%2!=0){condvar.notify_one();condvar.wait(lock,[&](){returni%2==0;});}i++;std::coutlock(mutex);if

c++ - std::function 的异常安全

我尝试查找这段代码是否会抛出异常,但没有成功:std::functionf=[]{};根据标准,std::function的复制或移动构造函数不是noexcept。但我想缺少noexcept关键字是因为std::function还包装了用户定义的仿函数对象,其复制或移动构造函数可能会抛出。在我的例子中,异常(exception)似乎不太可能,但有可能吗? 最佳答案 Inmycaseanexceptionseemsveryunlikelybutisitpossibleatall?原则上是的。std::function将不得不分配内存来

c++ - 如何将 tr1/array 转换为 std::string?

我想知道如何投std::tr1::array到std::string?编译器总是报错,我试过了std::tr1::arraysss;string(sss);stringasd(sss);两者都有效... 最佳答案 unsignedchar让这变得棘手。如果您知道您的系统使用2s补码1字节8位unsignedchar和char,以及从unsignedchar到char的隐式转换做你想做的(这些并不总是正确的!),并且你的数组缓冲区是null终止的(即,第一个0之后的字符应该被丢弃),这个函数有效:templatestd::string

C++ 使用命名空间声明

所以有一段时间我一直在使用...usingnamespace::std;最近我意识到这应该是usingnamespacestd;有人可以向我解释为什么我所做的工作有效,以及它与声明使用特定命名空间的正确方法有何不同? 最佳答案 第一个版本有效,因为编译器认为它是usingnamespace::std;//Noticespace^这只是告诉编译器在全局范围内寻找命名空间std。左侧没有任何内容的范围运算符::与全局范围相同。 关于C++使用命名空间声明,我们在StackOverflow上找