Visual Studio2010新特性--auto 数据类型自动类型判别

2023-10-19 17:32

本文主要是介绍Visual Studio2010新特性--auto 数据类型自动类型判别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转载于http://blog.csdn.net/itcastcpp/article/details/5367045

 

VC++2010在c++语言里面增加了一个特殊的新特性,c++语言可以自动判别数据类型,

而无需跟以前的c++语言一样,需要先定义数据,再使用,c++编译器将自动识别数据类型,

给程序员带来了更多的灵活性与便捷!

auto这个关键字来自VC++ 6.0标准。在VC++ 6.0中它没有什么作用,C++ 0x中“借用”它来作为自动类型推演(automatic type deduction)。当auto出现在声明中时,它表示“请用初始化我的表达式类型作为我的类型”。数据类型可以在编译时推演, 有了auto关键字再也不用写又长又烦的代码了。

请见下列代码,基于vc++2010编译器编译成功,采用图的数据结构进行演示。

 

  1. #include "stdafx.h"   
  2. #include <map>  
  3. #include <vector>  
  4. #include <string>  
  5. #include <iostream>  
  6.   
  7. using namespace std;  
  8.  
  9. #ifdef UNICODE  
  10.     #define tcout wcout  
  11. #else  
  12.     #define tcout cout  
  13. #endif  
  14.   
  15. const vector< basic_string<TCHAR> >* PrintContents(const map<int, vector< basic_string<TCHAR> > >& theMap)  
  16. {  
  17.     for each (auto m in theMap)  
  18.     {  
  19.         tcout << _T("Map element ") << m.first << _T(": ");  
  20.         for each(auto e in m.second)  
  21.         {  
  22.             tcout << _T("'") << e << _T("', ");  
  23.         }  
  24.         tcout << endl;  
  25.     }  
  26.     return NULL;  
  27. }  
  28.   
  29. int _tmain(int argc, _TCHAR* argv[])  
  30. {  
  31.     // / /定义一个图的数据结构,一个整数的字符串类型的字符串  
  32.     map<int, vector< basic_string<TCHAR> > > myMap;  
  33.     // 填充图数据  
  34.     vector< basic_string<TCHAR> > vec1;  
  35.     vec1.push_back(_T("string 1-1"));  
  36.     vec1.push_back(_T("string 1-2"));  
  37.     vec1.push_back(_T("string 1-3"));  
  38.     myMap[1] = vec1;  
  39.   
  40.     vector< basic_string<TCHAR> > vec2;  
  41.     vec2.push_back(_T("string 2-1"));  
  42.     vec2.push_back(_T("string 2-2"));  
  43.     vec2.push_back(_T("string 2-3"));  
  44.     myMap[2] = vec2;  
  45.   
  46.     // 输出图数据  
  47.     tcout << _T("Map contents:") << endl;  
  48.     for (map<int, vector< basic_string<TCHAR> > >::const_iterator citer = myMap.begin();  
  49.         citer != myMap.end(); ++citer)  
  50.     {  
  51.         tcout << _T("Map element ") << (*citer).first << _T(": ");  
  52.         for (vector< basic_string<TCHAR> >::const_iterator citer2 = (*citer).second.begin();  
  53.             citer2 != (*citer).second.end(); ++citer2)  
  54.         {  
  55.             tcout << _T("'") << (*citer2) << _T("', ");  
  56.         }  
  57.         tcout << endl;  
  58.     }  
  59.     tcout << endl;  
  60.   
  61.     // 输出图数据采用自动类型判别  
  62.     tcout << _T("采用自动类型判别:") << endl;  
  63.     for (auto citer = myMap.begin(); citer != myMap.end(); ++citer)  
  64.     {  
  65.         tcout << _T("Map element ") << (*citer).first << _T(": ");  
  66.         for (auto citer2 = (*citer).second.begin(); citer2 != (*citer).second.end(); ++citer2)  
  67.         {  
  68.             tcout << _T("'") << (*citer2) << _T("', ");  
  69.         }  
  70.         tcout << endl;  
  71.     }  
  72.     tcout << endl;  
  73.   
  74.     // 输出图数据采用自动类型判别(兼容 VC++ 2010)  
  75.     tcout << _T("自动类型判别:") << endl;  
  76.     for each (auto m in myMap)  
  77.     {  
  78.         tcout << _T("Map element ") << m.first << _T(": ");  
  79.         for each(auto e in m.second)  
  80.         {  
  81.             tcout << _T("'") << e << _T("', ");  
  82.         }  
  83.         tcout << endl;  
  84.     }  
  85.     tcout << endl;  
  86.   
  87.     // 打印图数据使用函数指针  
  88.     const vector< basic_string<TCHAR> >* (*p)(const map<int, vector< basic_string<TCHAR> > >&) = &PrintContents;  
  89.     tcout << _T("Map contents using a function pointer:") << endl;  
  90.     p(myMap);  
  91.     tcout << endl;  
  92.   
  93.     //打印 图数据借助自动类型输出使用函数指针  
  94.     auto f = &PrintContents;  
  95.     tcout << _T("Map contents using auto as a function pointer:") << endl;  
  96.     f(myMap);  
  97.     tcout << endl;  
  98.   
  99.     return 0;  
  100. }  

这篇关于Visual Studio2010新特性--auto 数据类型自动类型判别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/241310

相关文章

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

Python 常用数据类型详解之字符串、列表、字典操作方法

《Python常用数据类型详解之字符串、列表、字典操作方法》在Python中,字符串、列表和字典是最常用的数据类型,它们在数据处理、程序设计和算法实现中扮演着重要角色,接下来通过本文给大家介绍这三种... 目录一、字符串(String)(一)创建字符串(二)字符串操作1. 字符串连接2. 字符串重复3. 字

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

linux部署NFS和autofs自动挂载实现过程

《linux部署NFS和autofs自动挂载实现过程》文章介绍了NFS(网络文件系统)和Autofs的原理与配置,NFS通过RPC实现跨系统文件共享,需配置/etc/exports和nfs.conf,... 目录(一)NFS1. 什么是NFS2.NFS守护进程3.RPC服务4. 原理5. 部署5.1安装NF

Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧

《Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧》本文将通过实际代码示例,深入讲解Python函数的基本用法、返回值特性、全局变量修改以及异常处理技巧,感兴趣的朋友跟随小编一起看看... 目录一、python函数定义与调用1.1 基本函数定义1.2 函数调用二、函数返回值详解2.1 有返

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

python中的显式声明类型参数使用方式

《python中的显式声明类型参数使用方式》文章探讨了Python3.10+版本中类型注解的使用,指出FastAPI官方示例强调显式声明参数类型,通过|操作符替代Union/Optional,可提升代... 目录背景python函数显式声明的类型汇总基本类型集合类型Optional and Union(py