草庐IT

auto_cast

全部标签

C++11 外部作用域变量声明为 auto

在可用的C++中,对许多变量使用auto是一种很好的做法,尤其是那些类型已知但输入起来很烦人的变量:weird_template_type::subtype::recursive_subtypesome_function(){//...}//...autoval=some_function();在有意义的情况下,对RAII对象使用显微镜也很好,例如用于锁定:some_setup_code();intval;{lock_guardlk(mut);val=read_shared_memory();}do_something(val);有没有办法混合这两个成语,例如当您的共享内存读取代码返回

c++ - 为什么这个 map<int, auto> 是不允许的?

我正在尝试用C++实现异构映射。我知道之前已经讨论过这个问题,但我想知道为什么不允许以下内容:mapmyMap;有什么方法可以让我在不借助(void*)指针的情况下简单地插入map?我在考虑最终能够做这样的事情:vectorv;myMap.insert(make_pair(1,12334));myMap.insert(make_pair)(2,v));这可能吗?还是我的努力是徒劳的?谢谢 最佳答案 auto并不意味着“这可以是任何类型”。它是一个特殊的关键字,只能用于声明变量,其含义是“这个变量的类型与用来初始化它的表达式的类型相同

c++ - 在 C++ 中使用 auto 的最简单示例是什么?

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我试图理解auto在C++中是如何使用的。对我来说,理解某事的最好方法是看一个例子。然而,我看到的例子并不是那么简单。例如这里是“MeaningofC++0xautokeyword,byexample?”。要理解这个例子,我需要知道什么是"template"、“指针”、“malloc”等等。任何人都可以举一个使用auto的简单示例,以便人们可以轻松理解它的

c++ - 使用 '&'进行迭代时 'auto'符号有什么作用

最近我在C++中使用auto时遇到了非常非常奇怪的问题,只是......看看下面的代码片段:我的主要功能:#include#include#includeintmain(){inta=10,b=20,c=30;listwhat;what.push_back(a);what.push_back(b);what.push_back(c);read(what);return0;}这里的函数是:voidread(constlist&con){for(autoit:con){printf("%p\n",&it);cout这是输出:0x7fffefff66a4100x7fffefff66a4200

c++ - 无法在 VS 14 CTP : conditional expression of type 'void' is illegal 中使用 auto 声明 lambda

使用VisualStudio2014CTP、C++(v140)编译器:autogp=[&](BYTE*buff){autogp1=[](char*bff,char**p1){*p1=strstr((char*)bff,"(");return(*p1);};};错误:conditionalexpressionoftype'void'isillegal(也许auto真的输入错误?)如果我将内部lambda声明为std::functiongp1然后就可以了是我做错了什么还是编译器错误? 最佳答案 我没有运行2014,但您可能需要指定内部l

c++ - 函数返回 auto 自动参数 munmap_chunk() : invalid pointer

我正在测试newfeature对于GCC4.9(自动输入参数)并出现一些奇怪的错误。#include#includeautofoo(autov){for(auto&&i:v)std::cout{1,2,3});}这给我以下错误:***glibcdetected***./a.out:munmap_chunk():invalidpointer:0x00007f87f58c6dc0***=======Backtrace:=========/lib/x86_64-linux-gnu/libc.so.6(+0x7e846)[0x7f87f4e4c846]./a.out[0x400803]/lib

c++ - dynamic_cast 失败 - 取决于操作系统版本

我有一个失败的动态转换。类布局是这样的:classA1{public:virtualintfoo1()=0;};classA2{public:virtualintfoo2();};classA3{public:virtualintfoo3();};classB:publicA1,publicA2,publicA3{intbar();};现在我使用指针(因此不会发生切片)进行向下转换。main(){Bb;A1*a1=dynamic_cast(&b);//okB*b1=dynamic_cast(a1);//okA2*a2_1=dynamic_cast(a1);//OSX10.7ok,OSX

c++ - 为什么 dynamic_cast 存在?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Regularcastvs.static_castvs.dynamic_cast我通过这个问题了解了static_cast的工作原理。Whyisitimportanttousestatic_castinsteadofreinterpret_casthere?但如果static_cast确实知道类的继承关系,为什么dynamic_cast存在?我们什么时候必须使用dynamic_cast?

C++ 将 lexical_cast double boost 为字符串

对于下面的一段代码std::cout(2.34)我得到以下输出:2.3399999999999999如果我这样做doubled=2.34;std::stringstreamss;ss我得到以下输出:2.34为什么会这样?显然,我正在寻找后者的输出表示,而不是前者。谢谢, 最佳答案 这与boost::lexical_cast无关,但它伴随着double的内部表示:另请参阅此答案:C++internalrepresentationofdouble/float 关于C++将lexical_ca

c++ - <locale> 中的 "ctype"函数抛出 std::bad_cast

这个程序#include#includeintmain(){std::isxdigit(std::cin.peek(),std::cin.getloc());}抛出std::bad_cast类型的异常使用libstdc++使用gcc或clang编译时在我身上。用VS2010运行正常。我明白这里发生了什么。peek()返回int以适应带外EOF值。语言环境不需要ctype方面(他们在VS中确实有这个方面,也许作为扩展)。如果语言环境没有执行功能的方面,它将抛出bad_cast。.但这不应该按照原始的精神来工作吗??这是标准的缺陷吗?是否有普遍接受的解决方法?我知道我可以自己检查EOF并转