草庐IT

share_open_graph

全部标签

c++ - 提升.MultiIndex : Are there way to share object between two processes?

我有一个大约10Gb的Boost.MultiIndex大数组。为了减少读取,我认为应该有一种方法将数据保存在内存中,另一个客户端程序将能够读取和分析它。组织它的正确方法是什么?数组看起来像:structparticleID{intID;//realIDforparticlefromGadget2file"ID"blockunsignedintIDf;//postitioninthefileparticleID(intid,constunsignedintidf):ID(id),IDf(idf){}booloperator,BOOST_MULTI_INDEX_MEMBER(particl

c++ - Boost Graph Library 无向图 无平行边实现

我正在使用BoostGraphLibrary来处理无向图,并声明我的图有typedefproperty>VertexProperty;typedefadjacency_listUndirectedGraph;如您所见,OutEdgeList是std::set类型,我选择它是因为文档中说这种类型将强制不存在平行边。现在,我的程序读取一个文本文件,该文件指示节点之间的边,创建节点(如果以前没有看到)并在它们之间添加边。我最近跑了大数据量的代码,发现奇怪的结果。几个小时后,我发现一些用户的度数比图中的顶点数多,所以我用一个简单的文本文件尝试了代码,该文件只描述了同一对节点之间的两条边,但源、

c++ - QSqlQuery 内存问题。 QSqlQuery::exec() 和 QSqlDatabase::open()/close();

我正在检查我创建的应用程序的内存使用情况。它进行多次调用以从数据库(SQLite3)读取和写入值。我观察到以下内容:QSqlQuery::exec()使用一些KB的RAM来执行给定的查询,但在超出范围后不会释放内存。QSqlDatabase::open()和close()并不像文档中建议的那样帮助释放资源。如果有的话,close()会导致资源(至少是内存)在堆/堆栈上保持“受困”状态。例如,这是我用来访问数据库的典型代码段。QStringListvalues;db.open();QStringstrQuery="SELECTDISTINCT"+field+"FROM"+table+st

c++ - 为什么使用一个 vs 另一个 : `boost::shared_array` VS `boost::shared_ptr<std::vector>` ?

因此,要处理用于图像或类似内容的大内存块,显然有很多选择。因为我是智能指针和RAII的粉丝,所以我想知道它是否更智能:一个shared_ptr到一个std::vector或使用指向动态分配数组的shared_array。选择一个与另一个相比,在概念、实践和性能方面的影响是什么? 最佳答案 这与比较std::vector与C数组相同。将shared_array视为RAIIC数组。你得到的只是自动内存释放。在处理返回数组的第3方代码时很有用。理论上它在某些边缘情况下比std::vector更快,但灵active和安全性要差得多。std:

c++ - shared_ptr 与 CComPtr

我有点习惯通过COM进行引用计数的概念,但我对shared_ptr有点陌生。我在shared_ptr中没有找到CComPtr的几个不错的属性,我想知道防止误用shared_ptr的模式是什么。AddRef/Release模式保证每个对象只有一个引用计数(引用计数存储在对象本身),因此当您有一个随机指针围绕它创建一个CComPtr时,它是安全的。另一方面,shared_ptr有一个单独的refcount指针,所以在一个对象上创建一个新的shared_ptr是不安全的(为什么标准提供了一个构造函数,它在shared_ptr上采用T*,如果这样做很不安全?)。这似乎是一个很大的限制,我不明白

c++ - 在基类中调用 shared_from_this() 时的 bad_weak_ptr

我有一个SuperParent类,一个Parent类(派生自SuperParent)并且都包含一个shared_ptr到一个Child类(它包含一个weak_ptr到一个SuperParent)。不幸的是,我在尝试设置Child的指针时遇到了bad_weak_ptr异常。代码如下:#include#include#include#includeusingnamespaceboost;classSuperParent;classChild{public:voidSetParent(shared_ptrparent){parent_=parent;}private:weak_ptrpare

c++ - 适当使用 boost::shared_ptr?

关于boost::shared_ptr的问题:我有3个类(class)。A是某种负责管理一切的主类。B是一个类,它只具有完成某些工作的功能。Dispatcher只是一个围绕单独线程的类,它从B的Instaces中获取工作,在此线程中完成。所以它有点像这样工作:A有一个Dispatcher实例。现在,A偶尔会生成一个B的实例,并将其传递给调度程序。重要的是,B在完成后需要调用A::callback()。这就是为什么B在其构造函数中获取对A的引用(参见下面的代码)A.hppclassA:publicboost::enable_shared_from_this{public:A();void

c++ - OpenAL播放捕获的音频数据c++

我正在尝试使用OpenAL创建一个语音聊天程序。网络方面似乎没问题,但我会就此征求意见=]我目前遇到的问题是尝试播放从麦克风捕获的音频数据。我按照找到的代码here获取麦克风输入并将其回显给扬声器。这工作正常,但我似乎无法在捕获完成后播放完整捕获的音频。当一些声音被捕获后,我将它存储在一个列表中......for(inti=0;i然后在捕获完成后,我尝试(但失败了)使用以下代码来播放该音频ALuintplaybackSource;alGenSources(1,&playbackSource);errorCode=alGetError();ALuinttempPlayback;alBuf

c++ - 将 auto_ptr 转换为 shared_ptr

如何将std::auto_ptr更改为boost::shared_ptr?这是我的限制:1.我正在使用一个API类,让我们称之为only_auto返回这些指针2.我需要在auto_only中调用3.我的语义涉及共享,所以我确实需要使用shared_ptr)4.类中only_autooperator=private防止copy5.only_auto对象必须通过克隆调用std::auto_ptrcreat_only_auto();我知道模板显式shared_ptr(std::auto_ptr&r);但是我该如何在这种情况下使用它呢?一个super简化的代码示例:#include#inclu

c++ - 将 vector<shared_ptr<Derived>> 传递给需要 vector<shared_ptr<Base>> 的函数

我使用的代码结构有问题,如下(简化):classSPoint{public:SPoint(doublex,doubley,doublez):_x(x),_y(y),_z(z){}protected:double_x,_y,_z;}classPoint3D:publicSPoint{public:Point3D(doublex,doubley,doublez):SPoint(x,y,z){//defaultvaluesforUandV}protected:doubleU,V;}这些点用于创建折线:classSPolyline{public:SPolyline(constvector>&p