草庐IT

auto_flush

全部标签

c++ - 错误 : ‘i’ does not name a type with auto

这个问题在这里已经有了答案:HowdoIenableC++11ingcc?(4个答案)关闭7年前。我是C++新手,这是我的程序#include#include#include#include#includeintmain(){staticconstdoublearr[]={16.0,2.2,77.5,29.0,24.0};std::vectorvec(arr,arr+sizeof(arr)/sizeof(arr[0]));std::transform(vec.begin(),vec.end(),vec.begin(),bind2nd(std::minus(),3.0));for(aut

c++ - 将 auto_ptr 传递给函数可以有效地使其成为接收器。为什么?

我正在阅读一些关于共享指针的笔记。他们说STL对auto_ptr的第一次尝试有以下主要缺点:不能在STL容器中使用复制auto_ptr转移所有权将auto_ptr传递给函数有效地使其成为接收器我理解前两个,但不确定最后一个是什么意思。谁能解释一下。谢谢。 最佳答案 这是因为一旦将auto_ptr复制到一个变量中,您就失去了指向新变量的指针的所有权。当你有:voidfoo(std::auto_ptrx);并且您使用auto_ptr调用foo,您为foo复制了一份auto_ptr采用。这有效地将所有权转移到foo,因此指针在foo完成后

c++ - auto_ptr、immediate get() 和 release()——有用吗?

我正在处理别人的代码,其中包含很多这样的语句std::auto_ptrsmartptr(newObjectA(this));objects_list.push_back(smartptr.get());smartptr.release();这个有用吗?在这里使用智能指针而不是仅仅写有什么实际原因吗?objects_list.push_back(newObjectA(this)); 最佳答案 objects_list.push_back(newObjectA(this));这可能会泄漏内存。让我们看看当我们分解它时会发生什么:newO

c++ - auto* 在编译时有用还是 auto 关键字就足够了?

由于auto关键字在编译时获取类类型,我想知道使用auto*是否有任何效率,或者是否有任何特殊用途该表达式,因为auto在编译时已经获得了指针类型。 最佳答案 这个“新奇的C++11”与高效编译没有任何关系,除了在非常奇怪的极端情况下。所有这些都是为了让人类更容易编写和理解代码。auto*让您清楚地知道您拥有一个指针类型的值,并且编译器仅将其用作额外的类型检查标准,并且如果该类型不是指针类型,则会发出诊断信息——您的代码将出现格式错误,这是一个硬错误。我不记得auto*是否可以作为消歧器参与类型推导,但如果可以,那将是使用它的技术原

c++ - Foreach 范围迭代 vector<int> - auto 或 auto&?

游戏引擎微优化情况:我正在使用C++11范围for循环迭代vector,与auto关键字。什么更快:for(autovalue:ints)...或for(auto&value:ints)...? 最佳答案 在关心哪个更快之前,你应该关心哪个在语义上是正确的。如果你不需要改变被迭代的元素,你应该选择第一个版本。否则,您应该选择第二个版本。当然,您可能会反对,即使您不需要更改vector的内容,仍然可以选择使用对const的引用:for(autoconst&value:ints)然后问题就变成了:哪个更快?通过引用const还是通过值?

c++ - C++11 中的 auto 关键字奇怪行为

只是理论问题-为什么我不能写这样的代码:autoautofoo=0;第一个auto关键字-存储类说明符(是的,我知道它在C++11中没有用且已弃用),第二个auto关键字-auto类型说明符。怎么了?再一次-我真的不想在实际代码中使用它。 最佳答案 auto存储类说明符并非“在C++11中无用且已弃用”,它已被完全删除。auto关键字不再是存储类说明符,不能用作一个说明符。在C++11中,auto是一个简单的类型说明符。 关于c++-C++11中的auto关键字奇怪行为,我们在Stack

C++引用、内联函数、auto关键字介绍以及C++中无法使用NULL的原因

文章目录一、引用1.1引用概念1.2引用特性1.3常引用1.4使用场景1.4.1做参数1.4.2做返回值1.5引用和指针的区别1.6小结一下二、内联函数2.1内联的概念2.2内联的特性2.3【面试题】三、auto关键字(C++11)3.1类型别名思考3.2auto简介四、auto的使用细则4.1基于范围的for循环(C++11)4.2范围for的使用条件五、指针空值nullptr(C++11)一、引用1.1引用概念C++是C语言的继承,它可进行过程化程序设计,又可以进行以抽象数据类型为特点的基于对象的程序设计,还可以进行以继承和多态为特点的面向对象的程序设计。引用(reference)就是C+

c++ - std::move 与 std::auto_ptr 相比?

我可以用C++11中的“移动”(右值引用)做什么我不能用std::auto_ptr做什么?(据我了解,它们是一个想法的不同实现。)老问题又来了:std::auto_ptr是这么糟糕的组件吗? 最佳答案 C++98/03没有真正“可移动”类的概念。auto_ptr是一个具有transfer-on-copy-semantics的类,即当您制作拷贝时,原始内容会发生变化(注意带有非常量参数的复制构造函数!)。这是不好的。这样的类不能在标准容器中使用。由于新添加的右值引用概念,C++11引入了真正可移动类的概念。新的unique_ptr完全

c++ - 使用 auto 声明变量和使用类型名称有什么区别?

例如,我有一些类DataPacket。有什么区别:autopacket=DataPacket();和DataPacketpacket;? 最佳答案 先回答关于auto的问题,生成的代码没有区别:autopacket=DataPacket();和DataPacketpacket=DataPacket();但这不是你写的。在最初的问题中,第一个创建一个value-initialized临时对象,然后从中复制初始化packet。这需要一个可访问的、非显式的复制或移动构造函数,需要类型可以是默认构造的,并确保初始化packet(假设复制/移

c++ - 在类中使用返回 auto 的静态 constexpr 成员函数

我正在尝试解决我遇到的MSVC2015中的错误(请参阅此问题:wrongtypedeductionoffunctionsignature).所以我想到了这个:#includenamespacewreg{usingt_oshandle=HKEY;structt_api{staticconstexprautofnc_open_key(){return::RegOpenKeyExA;}//thisdoesn'tcompile:staticconstexprautoopen_key=fnc_open_key();//thesedon'tcompileeither://staticconstex