草庐IT

shared_lib

全部标签

c++ - 如何使用移动构造函数正确处理 shared_ptr 的映射?

假设我有一个容器std::map>我想用外部函数填充它并避免处理它的内容。所以我有typedefContainerstd::map>Container&&f(){Containerbar;autofoo=std::shared_ptr(newMyClass());bar.insert(std::make_pair(0,foo));std::coutprint_smthprint_smth如果我使用传统的复制构造函数,一切都会按预期工作。 最佳答案 这远太复杂了。为什么不直接说:intmain(){Containerbaz{{0,st

c++ - 使用由 ".h"、 ".lib"和 ".dll"文件组成的第三方库

所以目前我正在尝试使用NationalIntruments和IVIFoundation的VISA库来读取/写入各种外部设备的命令。我对我的IDE比较陌生:MicrosoftVisualC++Express2010,这是我第一次尝试使用需要超过.h导入的第三方库。基本上我有一个包含3个头文件的目录,一个包含3个.lib库的目录和一个包含7个DLL的目录。他们没有关于任何单个文件的功能的文档,只有整个库。因此,我需要能够获取与我的项目关联的所有这些文件。目前,我已将所有头文件导入到我的头文件中,并将头目录添加到项目属性的包含目录中。我还将包含.lib文件的目录添加到项目属性中的库目录中。我

c++ - 错误 : no instance of overloaded function "std::make_shared" matches the argument list

查看ApreviousstackQuestionstd:make_sharedvsstd::shared_ptr,我试图在一个uni项目中实现它。这是之前的“问题”:Ican'tthinkofanysituationwherestd::shared_ptrobj(newObject("foo",1));wouldbepreferredtoautoobj=std::make_shared("foo",1);因此我采用了这段代码:std::shared_ptrpT1(newTriangle(pCanvas,30,30,30,60,60,30,255,0,0));并将其修改为这段代码:aut

c++ - shared_ptrs 的 vector 行为神秘

我创建了一个Base类shared_ptr的vector来保存Derived类shared_ptr,并运行到一些问题。下面的简化示例显示了发生的情况。#include#include#includeusingnamespacestd;classBase{public:Base(inti):val(i){}intval;};classDerived:publicBase{public:Derived(inti):Base(i){}};intmain(){vector>vec1{make_shared(5),make_shared(99),make_shared(18)};for(auto

c++ - 包括来自/usr/local/include 的头文件和来自/usr/local/lib 的库

我刚刚在OSX10.9上安装了GLFW。header安装到/usr/local/include,库安装在/usr/local/lib。我想知道我还需要做些什么才能让我的C++程序包含像#include"GLFW/glfw3.h"这样的header,而不是像#这样指定整个路径包括“usr/local/include/GLFW/glfw3.h”。图书馆也是如此,因为到目前为止我什至无法使用-lglfw3链接图书馆。提前致谢。 最佳答案 您可以将-I/usr/local/include作为预处理器标志传递给编译器,将-L/usr/loca

Postgres安装目录中包含,共享,LIB目录和子目录和文件的功能是什么?

Postgres安装目录中包含,共享,LIB目录和子目录和文件的功能是什么?看答案这些文件是PostgreSQL软件的一部分。include包含所需的C标头文件编译使用C客户库库的客户端应用程序libpq和编译服务器扩展名为PostgreSQL。lib包含用于链接客户端应用程序的静态和动态库,是PostgreSQLServer的一部分的动态库和包含PostgreSQL扩展的动态库。share包含其他文件消息文件将PostgreSQL消息转换为各种语言,时区数据,配置文件用于全文搜索,配置文件的模板和扩展配置文件和脚本。

c++ - 核心转储的原因是什么?来自 oracle lib 的堆栈显示

我有一个coredmp,其中所有线程堆栈看起来都很正常,但一个堆栈显示如下。任何人都可以告诉我这可能的原因吗?我可以看到正在从oracle库调用exit,这是oracle的问题吗?当这种情况发生时,任何人都可以指导我吗?Thread3(process26454):#00x00002b803ceb54a8inexit()from/lib64/libc.so.6#10x00002b803bbe93f5inskgdbgcra()from/home/oracle/product/11g/lib/libclntsh.so.11.1#20x00002b803be9cdecinkpeDbgCrash

c++ - 为什么 std::shared_ptr 的别名构造函数不初始化 std::enabled_shared_from_this?

考虑以下代码:structFoo:std::enable_shared_from_this{};structBar{Foofoo;};intmain(){std::shared_ptrbar_p(newBar);//makeshared_ptrtomemberwithaliasingconstructorstd::shared_ptrfoo_p(bar_p,&bar_p->foo);assert(bar_p->foo.shared_from_this());//fail!throwsbad_weak_ptr}不幸的是,它没有按预期工作(至少在GCC4.8.2中)。我查看了代码,似乎别名

c++ - 对象 std::shared_ptr 是否可以通过它的 std::weak_ptr 找到?

所以我有一个std::vector>myListOfT;我有一个std::weak_ptrptrToOneT;它是从用于填充该容器的指针之一创建的(假设我将它放在回调函数中)。威尔std::find在那个容器和我的weak_ptr给我一个原始shared_ptr的迭代器(如果集合中存在这样的一个)?它是在标准的某处得到保证还是依赖于此实现? 最佳答案 通过使用std::weak_ptr::owner_before,我们可以不锁定weak_ptr。我将使用比必要的稍微冗长的解决方案并引入owner_equal,它与std::owner

c++ - 将库 (.lib) 链接到 Visual Studio 2013 项目

我按照link的说明构建了库.为了将该库链接到VisualStudio,我使用了以下方法,但它们都不能链接到我构建的.lib文件。Windows系统变量添加动态库路径(Environmentvariables->Path)设置为;C:\Users\venushka\Desktop\libxbee3-win32\libVisualStudio(包含头文件和源文件C++)配置属性->C/C++->常规->附加包含目录设置为C:\Users\venushka\Desktop\libxbee3-win32链接库配置属性->链接器->常规->附加库目录设置为C:\Users\venushka\D