草庐IT

auto_now_add

全部标签

c++ - 这是一个很好的 std::auto_ptr<> 用例吗?

请假设我有一个接受指针作为参数的函数。这个函数可以抛出异常,因为它使用std::vector::push_back()管理此指针的生命周期。如果我这样声明:voidmanage(T*ptr);并这样称呼它:manage(newT());如果它抛出异常将指针插入std::vector,我实际上有内存泄漏,不是吗?会像这样声明函数:voidmanage(std::auto_ptrptr);解决我的问题?我希望它首先分配std::auto_ptr在堆栈上(我猜永远不会抛出异常的东西)并让它获得对指针的所有权。安全的。然后,在函数内部,我将原始指针插入std::vector,这也是安全的:如果

c++ - 在 std::auto_ptr 的构造函数中使用 `explicit` 关键字有什么原因吗?

这是用于在VS2008编译器中从标准指针构造std::auto_ptr对象的构造函数。templateclassauto_ptr{public:explicitauto_ptr(_Ty*_Ptr=0)_THROW0():_Myptr(_Ptr){}private:_Ty*_Myptr;};explicit是否有任何特殊原因?上面使用关键字?换句话说,为什么我不能初始化auto_ptr与std::auto_ptrptr=newClassA;? 最佳答案 因为否则您可能会无意中执行以下操作:voidfoo(std::auto_ptrp)

c++ - 在多线程环境中使用 auto_ptr 交换对象而不锁定是安全的吗?

我在堆上分配了一些数据结构,它们很少被修改但需要快速读取访问。一个例子是在堆上分配的结构,许多线程以只读方式非常频繁地访问它。需要定期重写此结构并避免锁定争用我想知道使用auto_ptr是否安全基本上允许已获取引用的线程继续处理直到它们完成writer创建结构的拷贝,重写它并快速与结构的新auto_ptr实例交换指针。我从Java中的CopyOnWriteArrayList得到这个想法,并希望在C++中执行类似的性能。 最佳答案 std::auto_ptr在调用非常量成员(例如reset())时没有任何线程安全保证正如你所建议的。此

c++ - add 的位运算

你能帮我弄清楚为什么以下表达式为真:x+y=x^y+(x&y)我正在从按位逻辑中寻找一些规则来解释这个数学等价物。 最佳答案 这就像解决一个普通的以10为底的加法问题955+445,首先将所有列单独相加并丢弃带进位的1:955445-----390然后找到应该有进位1的所有列:955445-----101将其移动并将其添加到原始结果中:390+1010------1400所以基本上您是在做加法,但忽略所有进位的1,然后作为一个单独的步骤在后面添加进位的。在基数2中,当任一位为0时,XOR(^)正确执行加法。当两位都为1时,它会执行不

c++ - 使用 constexpr auto/char-array 变量观察到的不同行为

跟进这个问题Havingaconstexprstaticstringgivesalinkererror在问题中,这段代码无法编译:#includestructTest{staticconstexprchartext[]="Text";};intmain(){std::cout从评论来看,这段代码是可以编译的:#includestructTest{staticconstexprautotext="Text";};intmain(){std::cout我的问题是,为什么auto版本可以工作,而char版本的数组却不行?能否请您指出标准中允许使用第二个版本而不允许使用第一个版本的声明?我看了

c++ - (C++14) lambda 数组 : error: 'name' declared as array of 'auto'

我很难解决这个错误。我承认,我是C++的新手,我的困难来自于不理解错误消息。代码如下:autoselectionFuncs[8]={[&](constVector3&min,constVector3&max){returnmax.x_==seamValues.x_||max.y_==seamValues.y_||max.z_==seamValues.z_;},[&](constVector3&min,constVector3&max){returnmin.x_==seamValues.x_;},[&](constVector3&min,constVector3&max){returnm

c++ - 有什么理由不对 C++ 基于范围的 for 循环使用 auto& 吗?

例如循环:std::vectorvec;...for(auto&c:vec){...}将遍历vec并通过引用复制每个元素。是否有理由这样做?for(int&c:vec){...} 最佳答案 这两个代码片段将导致生成相同的代码:使用auto,编译器将确定底层类型是int,并执行完全相同的操作但是,auto的选项更“面向future”:如果在以后的某个时候您决定将int替换为,比如说,uint8_t为了节省空间,您无需遍历代码来查找对可能需要更改的基础类型的引用,因为编译器会自动为您完成。

c++ - 尝试使用 std::add_const 将 T& 转换为 const T&

我有一个T&,它有一个函数的const和非常量版本。我想调用该函数的const版本。我尝试使用std::add_const将T&转换为constT&但它不起作用。我做错了什么,我该如何解决?这是一个简单的例子。voidf(int&){std::cout::type>(r));}输出:int& 最佳答案 类型特征是解决这个问题的一种非常费力的方法。只需使用模板类型推导:voidf(int&){std::coutconstT&make_const(T&t){returnt;}intmain(){inta=0;int&r=a;f(make

c++ - 为什么我不能使用 auto 声明变量?

当我尝试声明一个类变量时,我在VisualStudio2015中遇到编译错误,而该类使用PIMPL模式。Foo.h:#pragmaonceclassFoo{public:Foo(conststd::wstring&str,conststd::vector&items);~Foo();private:structImpl;std::unique_ptrpimpl;};Foo.cpp:#include"stdafx.h"#include"Foo.h"structFoo::Impl{public:Impl(conststd::wstring&str,conststd::vector&item

c++ - 未解析的外部符号 boost::chrono::system_clock::now(void)

谷歌一直不友善...我最近取消了boost1.50,并尝试使用它来构建我的项目。这是一个大型项目,使用了多种boost功能(线程、信号、指针类、spirit等)。一些细节:-MSVC9.0(2008)-静态链接boost我在链接每个生成的exe时遇到错误,但是对于chrono,我没有直接链接它。错误是:libboost_thread-vc90-mt-sgd-1_50.lib(thread.obj):errorLNK2019:unresolvedexternalsymbol"public:staticclassboost::chrono::time_point>>__cdeclboost