草庐IT

shared_id

全部标签

c++ - 在 C 接口(interface)中使用 shared_ptr?

我有一个要移植到C++的C库,它大量使用手动引用计数结构。我考虑过使用shared_ptr来自动处理引用计数,但我还想维护CAPI。旧签名看起来像这样:Object*object_create(void);Object*object_retain(Object*o);voidobject_release(Object*o);如果我使用shared_ptr,有什么方法可以有效地在CAPI中公开此手动引用计数? 最佳答案 shared_ptr的问题,正如您已经发现的那样,您不能修改引用计数,除非通过构造或销毁实例。所以不,除了为每个构造

在Java中获得带有ID的卡片视图

您好,我目前正在进行AndroidStudio项目,我需要将CardView的可见性设置为“在我的布局中”。目前,我能够获得Java中的cardView的Webview。WebViewwebViewCO2;webViewCO2=(WebView)view.findViewById(R.id.webviewCO2);我有没有办法做同样的事情来获得卡片视图?看答案给CardView一个ID,例如CV_ID;做,CardViewcardView=(CardView)view.findViewById(R.id.cv_id);之后,您需要将其设置为何处,它可以消失,做,cardView.setVisi

c++ - 查找 boost::shared_ptr 循环引用

是否有查找shared_ptr的循环引用的任何提示/技巧?这是我要查找的示例-不幸的是,我似乎无法在我的代码中找到循环。structA{boost::shared_ptranC;};structB{boost::shared_ptranA;};structC{boost::shared_ptranB;}; 最佳答案 我建议使用Valgrind.当您关闭进程时,它会显示所有泄漏的内存。除非你的关机以某种方式打破了循环,否则任何循环都应该显示为内存泄漏,Valgrind会告诉你内存最初是从代码中的哪个位置分配的。

c++ - 通过 boost::shared_mutex 在 g++-4.4(不在 C++11/14 中)中实现多个读取器单个写入器是否会影响性能?

用法:在我们的产品中,我们有大约100个线程可以访问我们尝试实现的缓存。如果缓存丢失,则将从数据库中获取信息并通过编写器线程更新缓存。为此,我们计划实现多读单写我们无法更新g++版本,因为我们使用的是g++-4.4Update:Eachworkerthreadcanworkforbothreadandwrite.IfcacheismissedtheninformationiscachedfromtheDB.问题陈述:我们需要实现缓存来提高性能。为此,缓存读取更频繁,对缓存的写入操作要少得多。我认为我们可以使用boost::shared_mutexboost::shared_lock,b

c++ - 在 C++ 中生成唯一 ID

在C++中从两个(或更多)短整数生成唯一ID的最佳方法是什么?我正在尝试唯一标识图中的顶点。顶点包含两到四个短整数作为数据,理想情况下ID是它们的某种哈希。比起速度或易用性,更喜欢便携性和独特性。这里有很多很好的答案,今晚我将尝试所有这些答案,看看最适合我的问题。关于我正在做的事情再多说几句。该图是音频文件样本的集合。我将该图用作马尔可夫链,以从旧文件生成新的音频文件。由于每个顶点存储一些样本并指向另一个样本,并且样本都是短整数,因此从数据生成ID似乎很自然。将它们组合成一个longlong听起来不错,但也许像0123generateID这样简单的东西就是我所需要的。不确定需要多少空间

c++ - tr1::hash 用于 boost::thread::id?

我开始使用unordered_set来自tr1的类(class)命名空间以boost对普通(基于树的)STL的访问map.但是,我想在boost(boost::thread::id)中存储对线程ID的引用,并意识到这些标识符的API非常不透明,您无法清楚地获得它的哈希值。令人惊讶的是,boost实现了tr1的部分内容(包括hash和unordered_set),但它没有定义能够散列线程ID的散列类。查看boost::thread::id的文档我发现线程ID可以输出到流中,所以我的散列解决方案是这样的:structboost_thread_id_hash{size_toperator()

c++ - enable_shared_from_this 不适用于 xcode 5

#include#includetemplateclassTest:publicstd::enable_shared_from_this>{public:std::shared_ptr>getMe(){returnshared_from_this();};};intmain(intargc,constchar*argv[]){TestaTest;return0;}当我尝试在Xcode5上编译它时,我得到了Useofundeclaredidentifier'shared_from_this'我测试了它并在VisualStudio2010上运行。 最佳答案

c++ - 关于 boost::shared_ptr 赋值的问题(相对于 reset() 函数)

很抱歉,如果这在某个地方得到了明确的回答,但我对我在网上阅读的boost文档和文章感到有些困惑。我看到我可以使用reset()函数释放shared_ptr中的内存(假设引用计数变为零),例如,shared_ptrx(newint(0));x.reset(newint(1));我相信这会导致创建两个整数对象,并且在这两行的末尾,等于零的整数将从内存中删除。但是,如果我使用以下代码块会怎样:shared_ptrx(newint(0));x=shared_ptr(newint(1));显然,现在*x==1是真的,但是原始整数对象(等于零)会从内存中删除还是我泄漏了内存?在我看来,这可能是赋值

c++ - shared_ptr 和循环引用

我尝试使用boost::shared_ptr的循环引用,并设计了以下示例:classA{//Trivialclasspublic:i32i;A(){}A(i32a):i(a){}~A(){coutchangeI(shared_ptrs){s->i++;coutp1=make_shared(3);shared_ptrp2=p1;shared_ptrp3=p2;shared_ptrp4=p3;p1=p4;//1)1stcyclicref.cout哪些输出454~A:4是不是我误解了boost::shared_ptr中提到的循环引用?因为,在注释1)和2)之后,我期望对p1的间接引用的不同输

c++ - 使用 boost shared_ptr

我必须使用智能指针,我发现来自boost的“shared_ptr”看起来不错。我下载了boost库,在那里我可以看到很多文件和库。有没有办法只使用shared_ptr? 最佳答案 boostbcp是你的friend。它允许从它的树中提取单独的boost库。我过去成功地使用了它。shared_ptr仅包含header,因此这对您特别有用。 关于c++-使用boostshared_ptr,我们在StackOverflow上找到一个类似的问题: https://st