草庐IT

Unique_ptr

全部标签

Gradle Kotlin DSL : Define Kotlin version in unique place

为了描述Gradle构建脚本,我们可以通过build.gradle.kts使用Kotlin文件。在dependencies中全局定义要使用的Kotlin版本是一个常见问题。以及构建plugin部分(在给定的情况下使用不同的版本是相当少见的)。考虑以下代码(Gradle4.3.1):plugins{varpluginVersion="1.2.30"kotlin("jvm").version(kotlinVersion)//more}vardependencyVersion="1.2.30"dependencies{compile(kotlin("stdlib",kotlinVersion

python - Mongoengine unique_with

我在MongoDB中使用mongoengine。我必须制作一个文档,其中元组(merchant_id,order_id,event_type)必须是唯一键。到目前为止,我一直在处理仅限于两个领域的唯一性。所以下面的作品-merchant_id=StringField(required=True)order_id=StringField(required=True,unique_with='merchant_id')现在,我正在尝试为三个字段执行此操作-merchant_id=StringField(required=True)order_id=StringField(required=

node.js - Mongoose 架构 : Validating unique field, 不区分大小写

我有一个userSchema像这样:varuserSchema=newSchema({name:{type:String,required:true,validate:[validators.notEmpty,'Nameisempty']},username:{type:String,required:true,unique:true,validate:[validators.notEmpty,'Usernameisempty']}});username字段应该是唯一的。如果数据库中已经存在此用户名,Mongoose将抛出错误。但是,它不区分大小写,我需要它。我是否认为实现不区分大小写

c++ - 将 std::make_unique 与自定义删除器一起使用

在使用std::unique_ptr我希望使用自定义删除器std::make_unique而不是一个原始的新。我正在使用VC++2013。在我看来,没有办法使用std::unique_ptr如果您使用的是自定义删除器。我错过了什么还是真的是这样?附加信息:我正在使用std::unique_ptr为打开的COM端口保存一个WindowsHANDLE。我可以为此编写一个自定义的RAII类,这不会非常困难,但我看到使用std::unique_ptr会有多么困难/困难/糟糕。. 最佳答案 make_unique的全部意义在于封装“使用new

c++ - 通过传递指针的地址来初始化 std::unique_ptr

我正在创建一个与某些WindowsAPI代码互操作的类,现在我必须初始化的指针之一是通过调用初始化它的native函数来完成的。我的指针是std::unique_ptr类型,带有一个自定义删除器,它调用提供的WinAPI删除器函数,但是我不能将带有&地址运算符的unique_ptr传递给init函数.为什么?我创建了一个示例来演示我的问题:#includestructfoo{intx;};structcustom_deleter{};voidinit_foo(foo**init){*init=newfoo();}intmain(){std::unique_ptrfoo_ptr;init

c++ - 通过模板中的成员函数指针对 shared_ptr 的成员函数调用

这是一个模板函数,它接受一个指针(或类似对象的指针)和一个成员函数:templateintexample(Ptrptr,MemberFunctorfunc){return(ptr->*func)();}如果与普通指针一起使用时有效:structC{intgetId()const{return1;}};C*c=newC;example(c,&C::getId);//Worksfine但它不适用于智能指针:std::shared_ptrc2(newC);example(c2,&C::getId);错误信息:error:C2296:'->*':illegal,leftoperandhasty

c++ - 传递 const shared_ptr<T>& 而不是 shared_ptr<T> 作为参数

我已经阅读了大量关于应用程序中涉及智能指针时的性能问题的讨论。常见的建议之一是将智能指针作为const&而不是拷贝传递,如下所示:voiddoSomething(std::shared_ptro){}对voiddoSomething(conststd::shared_ptr&o){}但是,第二个变体实际上不是破坏了共享指针的目的吗?我们实际上在这里共享共享指针,因此如果由于某些原因指针在调用代码中被释放(考虑可重入性或副作用),则const指针将变为无效。共享指针实际上应该防止的情况。我知道const&节省了一些时间,因为不涉及复制,也没有锁定来管理引用计数。但代价是代码的安全性降低了

c++ - 在 std::shared_ptr 上使用 .reset() 是否会删除所有实例

我是shared_ptr的新手,我正在尝试找出.reset()函数的确切功能。#include#includeusingnamespacestd;classSomeClass{};intmain(){shared_ptrsp(nullptr);//dosomestuff,spnowhas10co-ownerscout会输出100所以自从我使用了重置功能后,所有实例都从内存中删除了吗?如,我刚刚用sp消除了任何可能的内存泄漏吗?显然这是我快速编造的一个玩具示例,如果有任何错误,请见谅。跟进情况:shared_ptrreturnThis(){shared_ptrsomeObject(new

c++ - 是否应允许 std::unique_ptr<void>

这是一个非常简单的问题。考虑以下代码:#include#includetypedefstd::unique_ptrUniqueVoidPtr;intmain(){UniqueVoidPtrp(newint);return0;}使用以下命令g++-std=c++0x-oprogfile.cpp用cygwin(g++4.5.3)编译就可以了。但是,使用microsoft编译器(VS2010或2013)编译时出现此错误:C:\ProgramFiles(x86)\MicrosoftVisualStudio10.0\VC\INCLUDE\memory(2067):errorC2070:'void

c++ - unique_ptr 线程安全吗?

unique_ptr线程安全吗?下面的代码不可能两次打印相同的数字吗?#include#include#include#includeusingnamespacestd;intmain(){unique_ptrwork;threadt1([&]{while(true){constunique_ptrlocalWork=move(work);if(localWork)printf("thread1:%d\n",*localWork);this_thread::yield();}});threadt2([&]{while(true){constunique_ptrlocalWork=mov