草庐IT

auto_ptr_ref

全部标签

c++ - `auto` 说明符的编译时间是否较慢?

从C++11开始,我们可以使用autoa=1+2而不是inta=1+2并且编译器推断出a的类型本身。它是如何工作的?在编译时(更多操作)是否比自己声明类型慢? 最佳答案 auto要求C++11编译器生成一些有限typeinference(查看Ocaml如果你想要一些更性感的类型推理语言)。但是开销只是编译时的。如果你替换autoa=1+2;与inta=1+2;(两者具有相同的含义,请参阅answerbysimplicis)并且如果您要求编译器optimize(甚至可能不要求优化)你可能会得到相同的machinecode.另见this

c++ - 使用(和导出)boost::shared_ptr<T> 时出现错误 C2562

各位程序员好,我正在创建一个C++DLL库,我在其中使用了boost(1.55)的shared_ptr。然而,当我使用VisualStudio2013编译项目时,出现了一堆错误C2562:Error1errorC2562:'boost::shared_ptr::operator[]':'void'functionreturningavaluef:\developer\cplus\lib\boost_1_55_0\boost\smart_ptr\shared_ptr.hpp6631MEngineError2errorC2562:'boost::shared_ptr::operator[]

git pull 时出现error: cannot lock ref 问题

出现原因git工程下的目录.git/refs目录的追踪分支,与其远程仓库对应的分支refs不同,导致gitpull操作失败。出现对应分支refs不同原因其他开发者使用了gitpush-force进行强推代码。git分支是不区分大小写的,有人删除了远程仓库的分支并重新创建了一个同名字的分支。解决方案删除有问题的refs,可以直接在.git/refs下根据提示删除对应的refs文件,也可以删除整个refs文件夹。强制执行pull,使用gitpull-p。使用git命令更新其对应,gitupdate-ref-drefs/xxx/xxx/xxx。

c++ - 如何将 boost::shared_ptr 作为指向 Windows 线程函数的指针传递?

如何将boost::shared_ptr作为指向Windows线程函数的指针传递?假设以下代码:test::start(){...._beginthreadex(NULL,0,&test::threadRun,&shared_from_this(),0,&threadID);......}/*thisisastaticfunction*/UINT__stdcalltest::threadRun(LPVOIDlpParam){shared_ptrk=*static_cast*>(lpParam);...}我认为这段代码不正确,你的想法是什么?我该怎么做?编辑:我通过boost::weak

【C++】C++11——智能指针、内存泄漏、智能指针的使用和原理、RAII、auto_ptr、unique_ptr、shared_ptr、weak_ptr

文章目录C++117.智能指针7.1内存泄漏7.2智能指针的概念7.3智能指针的使用7.3.1auto_ptr7.3.2unique_ptr7.3.3shared_ptr7.3.4weak_ptrC++117.智能指针7.1内存泄漏  什么是内存泄漏:  内存泄漏指因为疏忽或错误造成程序未能释放已经不再使用的内存的情况。内存泄漏并不是指内存在物理上的消失,而是应用程序分配某段内存后,因为设计错误,失去了对该段内存的控制,因而造成了内存的浪费。  内存泄漏通常由于程序在设计上的缺陷或错误,例如动态分配内存后,未在合适的时间或无法正确释放该段内存,而导致的。内存泄漏通常需要程序员通过分析程序源代码

c++ - ConnectNamedPipe 和 asio overlapped ptr

我命名了使用boostasio编写的管道服务器。服务器创建命名管道并调用ConnectNamedPipe将asiooverlappedptr传递给它。问题是传递给重叠的asio的完成处理程序从未被调用,即在客户端调用CreateFile不会触发传递给ConnectNamedPipe的完成处理程序。我做错了什么?这里是客户端和服务器的完整列表:#define_WIN32_WINNT0x0501#include#include#include#include#include#include#include#include#includestaticconstuint32_tPIPE_OUT

windows - MS.Internal.XcpImports.MethodEx(IntPtr ptr, String name, CValue[] cvData

我收到错误消息“值不在预期范围内”。堆栈跟踪在下面给出。请帮忙...atMS.Internal.XcpImports.MethodEx(IntPtrptr,Stringname,CValue[]cvData)atMS.Internal.XcpImports.MethodPack(IntPtrobjectPtr,StringmethodName,Object[]rawData)atMS.Internal.XcpImports.UIElement_TransformToVisual(UIElementelement,UIElementvisual)atMicrosoft.Phone.Con

Git 推送代码提示 failed to push some refs to ‘xxx.git‘

1.问题详情登录并使用Github创建远程仓库并将创建好的远程仓库通过git命令gitremoteadd和本地仓库关联绑定后使用git提交时出现该错误。该该问题提示内容均为error:failedtopushsomerefsto远程仓库地址,例如error:failedtopushsomerefsto'git@github.com:xiaoming/hello.git2.问题原因我们在使用Github创建远程仓库的时候,勾选了使用Reamdme文件初始化这个仓库选项,该选项在创建远程仓库时会自动生成README文件并配置.gitignore忽略文件,同时Github会自动帮助我们做一次初始提交

windows - C++/命令行界面 : Public ref struct generates C2011: 'class' type redefinition

我在托管DLL项目中有一个头文件,如下所示:枚举.h:#pragmaonce...publicrefstructManagedStruct{Bitmap^image;}...此header被DLL中的另一个类和单独的可执行文件引用。单独的托管结构正在生成:errorC2011:'ManagedStruct':'class'typeredefinition.如果我将结构移动到DLL中的主头文件,它工作正常,并且可以公开访问,所以这就是我正在做的,但我非常想知道为什么当我移动它时会发生这种情况到另一个文件。我已经检查了所有必要的包含和namespace,并尝试了明显的标题保护,但无济于事;

windows - DWORD_PTR、INT_PTR、LONG_PTR、UINT_PTR、ULONG_PTR 何时、如何以及为什么?

我发现Windows有一些新的WindowsDataTypesDWORD_PTR,INT_PTR,LONG_PTR,UINT_PTR,ULONG_PTR你能告诉我何时、如何以及为什么使用它们吗? 最佳答案 *_PTR类型被添加到WindowsAPI以支持Win64的64位寻址。由于32位API通常使用DWORD等数据类型传递指针,因此有必要为64位兼容性创建新类型以替代32位应用程序中的DWORD,但是在64位应用程序中使用时扩展到64位。因此,例如,想要编写32位或64位代码的应用程序开发人员将windows32位APISetWi