草庐IT

weak_ptr_cast

全部标签

c++ - 为什么此 reinterpret_cast 在 Visual Studio 中失败?

我有一些代码(见下文),奇怪的是,当我通过gcc运行代码时它编译得很好,但是当我在VisualStudio2017中打开相同的文件时,我得到一个编译器错误,如下所示:ErrorC2440'reinterpret_cast':cannotconvertfrom'::size_t'to'Alias'这是一个最小的示例,如果您愿意,可以尝试一下。只需点击“新建项目”,然后选择C++Windows控制台应用程序,插入这段代码,并尝试在默认的x86Debug模式下编译:#include"stdafx.h"#includetypedefstd::size_tAlias;AliasmakeAlias

c++ - const_cast 和 UB

$5.2.11/7-"[Note:Dependingonthetypeoftheobject,awriteoperationthroughthepointer,lvalueorpointertodatamemberresultingfromaconst_castthatcastsawayaconst-qualifier68)mayproduceundefinedbehavior(7.1.5.1).]"这部分(C++03)的措辞让我感到惊讶。令人惊讶的是两件事。a)首先,“可能”的使用。为什么是“可以”?标准中的其他地方对未定义的行为非常明确b)为什么不是直接抛弃“未定义行为”的原始co

c++ - 在简单的情况下使用 scoped_ptr 是否有点矫枉过正?

我在像这样的小函数中使用scoped_ptr。这样我就不必调用delete了。这是这种用法的矫枉过正吗?我的团队成员更喜欢原始指针和删除。如果这恰好用在非常关键的路径中,那么使用scoped_ptr的成本是多少?这不应该是内联的并且完全等同于在优化的二进制文件中使用普通删除吗?voidmyfunc(){boost::scoped_ptrobjptr=someFactory::allocate();callsomeotherfunc(objptr.get());} 最佳答案 我不确定对性能的影响,但是在这里使用scoped_ptr确保

c++ - 应该使用哪个 header 来使用 scoped_ptr

我想在我的C++应用程序中使用智能指针。使用stdscoped_ptr应该包含哪个头文件? 最佳答案 标准C++库中没有scoped_ptr。全部C++11smartpointers在标题中.如果你想要boost::scoped_ptr那么你需要boost/scoped_ptr.hpp. 关于c++-应该使用哪个header来使用scoped_ptr,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/q

c++ - 是否可以使用 static_cast 避免 vtable 开销?

这是我的问题。我有一个基类和一个派生类,它覆盖了基类中的一些方法。为简单起见,请考虑以下示例:structbase{virtualvoidfn(){/*basedefinitionhere*/}};structderived:base{voidfn(){/*deriveddefinitionhere*/}};在我的实际程序中,这些类作为参数传递给其他类并在其他方法中调用,但为了简单起见,让我们创建一个简单的函数,将基类或派生类作为参数。我可以简单地写voidcall_fn(base&obj){obj.fn();}并且由于虚函数的缘故,对适当函数的调用将在运行时解析。但是,我担心如果ca

c++ - 使用 shared_ptr 时奇怪的双析构函数调用

最后我找到了一个非常奇怪的错误,这是由两次调用析构函数引起的。这是重现错误的最少代码:#include#include#includeclasscEventSystem{public:cEventSystem(){std::cout(eventSystem);}voidonEvent(){}std::shared_ptrtileBrowser;};intmain(){cEventSystemeventSystem;cGuigui(eventSystem);}输出是:constructor:0x7fffffffe67fdestructor:0x7fffffffe2dfdestructor

c++ - 如何将 "cast"一个双参数函数转换为一个参数函数?

在matlab中,可以这样写:S=@(x,y)x^2+y^2-1G=@(x)S(x,1);如果我有一个需要单参数函数的函数,我可以执行上述操作。我如何在c/c++中执行此操作?我有一个库函数(来自CGAL库),它期望一个本身只有一个参数的函数作为参数。理想情况下,我有一个类(SphericalHarmonics),我希望有一个接受一个参数的成员函数。所以我有:FTSphericalHarmonics::distFunction(Point_3p)(注意FT是一个类似于double的类型)但是当然当我尝试SphericalHarmonics*sh=newSphericalHarmonic

c++ - 在赋值运算符中分配 std::shared_ptr

我正在创建自己的自定义Filter类以用于boost::filtered_graph。WeightMap概念必须具有默认构造函数、复制构造函数和赋值运算符。我创建了下面的类,它有一个std::shared_ptr私有(private)成员。我的问题是我应该如何编写赋值运算符。复制构造函数没有问题,但赋值运算符不起作用。classBFDMFilter{private:constBGraph*m_battlemap;conststd::shared_ptrm_mv_ab;public:BFDMFilter():m_battlemap(nullptr),m_mv_ab(){}BFDMFilt

c++ chrono duration_cast 到毫秒结果以秒为单位

我想要自纪元以来的毫秒数。一个流行的解决方案如下所示(这里提出的这个问题的解决方案之一Gettimesinceepochinmilliseconds,preferablyusingC++11chrono)#include#includeintmain(){automillitime=std::chrono::duration_cast(std::chrono::system_clock::now().time_since_epoch()).count();std::cout通过调用g++来编译它,比如g++-std=c++11main.cpp-otimetest产生输出13726860

c++ - std::unique_ptr 试图引用已删除的函数

我已经使用Unity一段时间了,然后回来使用VisualStudio2015做一些C++。我遇到了这个类定义classA{public:A();virtual~A();A(constA&)=delete;A&operator=(constA&)=delete;private:…}这个类是动态分配的,如下所示:ObjPtrobj=ObjPtr(newA());哪里ObjPtr是定义的类型,看起来像:typedefstd::unique_ptrobjPtr;并将这些创建的对象添加到std::vector使用std::move.有一次,我需要遍历对象列表,如果我找到满足我条件的对象,请保留一