草庐IT

LONG_PTR

全部标签

c++ - 在 C++03 中返回类似 `std::auto_ptr` 的集合的最佳方法是什么?

std::auto_ptr不允许存储在STL容器中,例如std::vector.但是,偶尔会出现需要返回多态对象集合的情况,因此无法返回对象vector(由于切片问题)。我可以使用std::tr1::shared_ptr并将它们粘贴在vector中,但随后我不得不为维护单独的引用计数付出高昂的代价,并且拥有实际内存(容器)的对象在逻辑上不再“拥有”这些对象,因为它们可以在不考虑所有权的情况下从中复制出来。C++0x以std::vector>的形式为这个问题提供了完美的解决方案。,但我无权访问C++0x。一些其他注意事项:我无法访问C++0x,但我可以使用TR1。我想避免使用Boost(

c++ - unique_ptr C++03仿真中的move函数

我正在尝试了解如何C++03emulationofunique_ptr实现。unique_ptr很像std::auto_ptr但更安全。在auto_ptr会隐式(即静默)转移所有权的情况下,它会吐出编译器错误。例如,一个简单的任务。函数move是模拟unique_ptr安全性背后的关键。问题:为什么有三个move函数?接受引用并将其转换为右值的第三个move函数实现(简化)如下。Tmove(T&t){returnT(detail_unique_ptr::rv(t));}在上面的代码中,到T的显式转换似乎没有必要。事实上,VisualStudio2010在没有显式转换为T的情况下非常满意

c++ - 诸如 `msg(long)` 与候选 `msg(int32_t)` 和 `msg(int64_t)` 等函数的模糊重载

注意:这与Determinenumberofbitsinintegraltypeatcompiletime非常相似,但是这是一个非常简化的版本,所有内容都包含在一个.cpp中编辑:添加了一个解决方案-尽管给出了(并接受)了正确的解释,但我找到了一种通用的解决问题的方法。问题问题在于像这样的函数msg(int32_t);msg(int64_t);像这样的电话longlongmyLong=6;msg(myLong);//Won'tcompileongcc(4.6.3),callisambiguous这在MSVC上编译。谁能解释为什么这在gcc上失败(我假设这可能与gcc通常严格符合标准这一

c++ - 附加调试器时 unique_ptr dtor 调用速度慢得离谱 (msvc)

structtest_struct{test_struct(){}~test_struct(){}};#include#include#includeintmain(){printf("ctorbegin\n");{std::vector>test_vec;constintcount=100000;for(autoi=0;i我正在使用VS2010,发现了一些荒谬的性能问题。上面的代码在调试和发布版本(ctrl+f5)中都运行良好,但是当附加调试器(f5)时,dtor调用unique_ptr类的速度慢得无法忍受。结果机器代码是相当优化的,所以我不认为这是编译器问题而不是调试器问题,但我不

c++ - 将多边形坐标从 Double 转换为 Long 以用于 Clipper 库

我有两个多边形,它们的顶点存储为Double坐标。我想找到这些多边形的交叉区域,所以我正在查看Clipperlibrary(C++版本)。问题是,Clipper仅适用于整数数学(它使用Long类型)。有没有一种方法可以用相同的比例因子安全地转换我的两个多边形,将它们的坐标转换为Longs,使用Clipper执行相交算法,并使用相同的比例缩小生成的相交多边形,然后将其转换回来到Double而不会损失太多精度?我不太清楚该怎么做。 最佳答案 您可以使用一个简单的乘数在两者之间进行转换:/*Usingpower-of-twobecause

C++11 非拥有引用/指向 unique_ptr 的指针?

这不是“如何做”的问题,而是“如何以正确的方式做”的问题我正在Qt中开发一个编辑器,其中不同的小部件显示子项及其(成员)变量。这些小部件中的每一个都应该保存一个指向已编辑子项的引用/指针,以显示和更改它们的成员变量。第一次尝试是我学习(并且仍然有点坚持)的旧ANSIC方法,使用指向所用对象的简单原始指针。它工作正常,但由于C++11标准支持智能指针并建议使用它们,我正在尝试使用它们。问题是,我不太确定在这种情况下使用它们的“最佳方式”是什么......看完SmartPointers:Orwhoownsyoubaby?和WhichkindofpointerdoIusewhen?和其他一些

c++ - 如何从 boost 库中取出单个元素(例如 shared_ptr)?

我一直在玩弄一些Boost组件,我认为在我正在从事的项目中唯一直接需要的是boost::shared_ptr。只包含shared_ptr所需的文件会很困难,或者至少只包含Boostsmart_ptr目录的文件到我的项目中?它们似乎对Boost的其他部分有一些外部依赖性-但我认为有一种简单的方法可以只使用Boost库的某些组件,而我错过了它。如果您能告诉我我需要哪些部分或指出一个好的教程,我将不胜感激! 最佳答案 您可以使用bcp工具仅提取所需的header。bcpshared_ptr/foo这会将shared_ptr和所有依赖项复制

c++ - 对持有 unique_ptr vector 的对象列表进行排序

根据C++11,以下代码是否会产生编译错误(如果是,为什么?)还是VC11的问题?#include#include#includestructA{std::vector>v;};intmain(){std::listl;l.sort([](constA&a1,constA&a2){returntrue;});}VisualC++2012产生以下编译错误:1>c:\programfiles(x86)\microsoftvisualstudio11.0\vc\include\xmemory0(606):errorC2248:'std::unique_ptr::unique_ptr':can

c++ - boost::shared_ptr 和 std::shared_ptr 共存

我们都知道boost和c++11都支持shared_ptr。有些编译器支持c++11,有些则不支持。我想编写我的代码,以便当编译器支持c++11shared_ptr时,它使用std::shared_ptr;如果没有,请使用boost::shared_ptr。这方面的常见/最佳做法是什么?让我将讨论限制在GCC而不是特定版本。 最佳答案 C++0x/C++11可用性到目前为止,我知道检测GCC是否使用C++0x/C++11的唯一方法是检查预定义宏__GXX_EXPERIMENTAL_CXX0X__:#ifdef__GXX_EXPERI

c++ - shared_ptr 不能为空?

使用std::shared_ptr表示共享所有权和可选性(可能为空)。我发现自己处于这样一种情况,我只想在我的代码中表达共享所有权,而没有任何选择权。当使用shared_ptr作为函数参数时,我必须让函数检查它是否不为null以保持一致/安全。在许多情况下,传递引用而不是当然是一种选择,但有时我也想转让所有权,因为可以使用shared_ptr。是否有一个类可以替换shared_ptr而不可能为空,是否有一些约定来处理这个问题,或者我的问题没有多大意义? 最佳答案 您正在请求not_null包装器类。幸运的是,C++专家已经解决了您的