size_type、size_t、differentce_type以及ptrdiff_t

简介:
 

 

 

 

 

复制代码
size_t是unsigned类型,用于指明数组长度或下标,它必须是一个正数,std::size_t

ptrdiff_t是signed类型,用于存放同一数组中两个指针之间的差距,它可以使负数,std::ptrdiff_t.

size_type是unsigned类型,表示容器中元素长度或者下标,vector<int>::size_type i = 0;

difference_type是signed类型,表示迭代器差距,vector<int>:: difference_type = iter1-iter2.

前二者位于标准类库std内,后二者专为STL对象所拥有。
复制代码

 

 

size_type

    在标准库string类型中,最容易令人产生误解就是size()成员函数的返回值了,如果不深入分析的话,大多人都会认为size()的返回值为int类型,其实不然。事实上,size操作返回的是string::size_type类型的值。 那怎样理解size_type这一类型呢,我引用《C++ Primer》一段原文简单解释一下:
    string类类型和许多其他库类型都定义了一些配套类型(companion type)。通过这些配套类型,库类型的使用就能和机器无关(machine-independent)。size_type就是这些配套类型中的一种。它定义为与unsigned型(unsigned int 或 unsigned long)具有相同的含义,而且可以保证足够大能够存储任意string对象的长度。为了使用由string类型定义的size_type类型,程序员必须加上作用域操作符来说明所使用的size_type类型是由string类定义的。

 

[cpp]  view plain copy
  1. /******************************************* 
  2.  * this is a simple demo to test size_type 
  3.  * 
  4.  * Auther : Jerry.Jiang 
  5.  * Date : 2011/08/20 
  6.  * http://blog.csdn.net/jerryjbiao 
  7.  * 
  8.  *********************************************/  
  9.   
  10. #include <iostream>  
  11. #include <string>  
  12.   
  13. using namespace std;  
  14.   
  15. int main()  
  16. {  
  17.     string str("This is a simple demo !");  
  18.   
  19.     for (string::size_type index = 0; index != str.size(); ++index)  
  20.     {  
  21.         cout << str[index];  
  22.     }  
  23.     cout << endl;  
  24.   
  25.     return 0;  
  26. }  

      这里特别注意的是:任何存储string的size操作结果的变量必须为string::size_type类型,同时,使用size_type类型时,必须指出该类型是在哪里定义的。切记不要吧size的返回值赋给一个int变量。

     不仅string类型定义了size_type,其他标准库类型如vector::size_type,list::size_typedeque::size_type,map::size_typemultimap::size_type ,basic_string::size_type 等更多请查看MSDN详细介绍。下面是几个常用的Demo:

[cpp]  view plain copy
  1. /******************************************* 
  2.  * this is a simple demo to test vector::size_type 
  3.  * 
  4.  * Auther : Jerry.Jiang 
  5.  * Date : 2011/08/20 
  6.  * http://blog.csdn.net/jerryjbiao 
  7.  * 
  8.  *********************************************/  
  9.   
  10. #include <iostream>  
  11. #include <vector>  
  12.   
  13. using namespace std;  
  14.   
  15. int main()  
  16. {  
  17.     vector<int> ivec;  
  18.   
  19.     //vector::size_type   
  20.     for (vector<int>::size_type ix = 0 ; ix != 10; ++ix)  
  21.     {  
  22.         ivec.push_back(ix+1);  
  23.     }  
  24.   
  25.     //vector::iterator  
  26.     for (vector<int>::iterator iter = ivec.begin();  
  27.                                iter != ivec.end(); ++iter)  
  28.     {  
  29.         cout << *iter << "  ";  
  30.     }  
  31.   
  32.     cout << endl;  
  33.     return 0;  
  34. }  
[cpp]  view plain copy
  1. /******************************************* 
  2.  * this is a simple demo to test list::size_type 
  3.  * 
  4.  * Auther : Jerry.Jiang 
  5.  * Date : 2011/08/20 
  6.  * http://blog.csdn.net/jerryjbiao 
  7.  * 
  8.  *********************************************/  
  9.   
  10. #include <list>  
  11. #include <iostream>  
  12.   
  13. using namespace std;  
  14.   
  15. int main( )  
  16. {  
  17.   
  18.    list <int> c1;  
  19.    list <int>::size_type i;  
  20.      
  21.    c1.push_back( 1 );  
  22.    i = c1.size( );  
  23.    cout << "List length is " << i << "." << endl;  
  24.   
  25.    c1.push_back( 2 );  
  26.    i = c1.size( );  
  27.    cout << "List length is now " << i << "." << endl;  
  28.   
  29.    return 0;  
  30. }  
[cpp]  view plain copy
  1. /******************************************* 
  2.  * this is a simple demo to test map::size_type 
  3.  * 
  4.  * Auther : Jerry.Jiang 
  5.  * Date : 2011/08/20 
  6.  * http://blog.csdn.net/jerryjbiao 
  7.  * 
  8.  *********************************************/  
  9.   
  10. #include <map>  
  11. #include <iostream>  
  12.   
  13. int main()  
  14. {  
  15.     using namespace std;  
  16.     map<intint> m1, m2;  
  17.     map<intint>::size_type i;  
  18.     typedef pair<intint> Int_Pair;  
  19.   
  20.     m1.insert(Int_Pair(1, 1));  
  21.     i = m1.size();  
  22.     cout << "The map length is " << i << "." << endl;  
  23.   
  24.     m1.insert(Int_Pair(2, 4));  
  25.     i = m1.size();  
  26.     cout << "The map length is now " << i << "." << endl;  
  27.       
  28.     return 0;  
  29. }  
    • size_t

          size_t类型定义在cstddef头文件中,该文件是C标准库中的头文件 stddef.h 的C++版本。它是一个与机器相关的unsigned类型,其大小足以存储内存中对象的大小。

           与前面Demo中vector和string中的size操作类似,在标准库类型bitset中的size操作和count操作的返回值类型为size_t 。

      [cpp]  view plain copy
      1. /*********************************************** 
      2.  * this is a simple demo to test bitset::size_t 
      3.  * 
      4.  * Auther : Jerry.Jiang 
      5.  * Date : 2011/08/20 
      6.  * http://blog.csdn.net/jerryjbiao 
      7.  * 
      8.  *********************************************/  
      9.   
      10. #include <iostream>  
      11. #include <bitset>  
      12.   
      13. using namespace std;  
      14.   
      15. int main()  
      16. {  
      17.     //bitvec有32位,每位都是0  
      18.     bitset<32> bitvec;  
      19.     cout << " bitvec : " << bitvec << endl;  
      20.       
      21.     //count()统计bitvec中置1的个数  
      22.     size_t bitcount = bitvec.count();  
      23.     cout << "bitvec.count() :" << bitcount << endl;  
      24.   
      25.     //size()统计bitvec二进制位的个数  
      26.     size_t bitsize = bitvec.size();  
      27.     cout << "bitvec.size() :" << bitsize << endl;  
      28.   
      29.     return 0;  
      30. }  
    • differentce_type


          一种由vector类型定义的signed整型,用于存储任意两个迭代器间的距离
    • ptrdiff_t


          与size_t一样,定义在cstddef头文件中定义的与机器相关的有符号整型,该类型具有足够的大小存储两个指针的差值,这两个指针指向同一个可能的最大数组。

      来源:http://blog.csdn.net/jerryjbiao/article/details/6705331





本文转自夏雪冬日博客园博客,原文链接:http://www.cnblogs.com/heyonggang/p/3264422.html,如需转载请自行联系原作者
目录
相关文章
|
存储 Java 定位技术
gis利器之Gdal(二)shp数据读取
本文首先简单介绍了空间数据shp数据的基本知识,其常见的文件组成形式。使用qgis软件对数据进行常规预览,最后重点介绍了使用gdal对矢量信息进行读取,​包括空间信息和属性信息
1633 0
gis利器之Gdal(二)shp数据读取
|
Shell 文件存储 Android开发
智能电视安装VLC配合frpc实现播放远程群晖NAS上的电影
智能电视安装VLC配合frpc实现播放远程群晖NAS上的电影
2370 0
|
7月前
|
存储 人工智能 自然语言处理
构建智能AI记忆系统:多智能体系统记忆机制的设计与技术实现
本文探讨了多智能体系统中记忆机制的设计与实现,提出构建精细化记忆体系以模拟人类认知过程。文章分析了上下文窗口限制的技术挑战,并介绍了四种记忆类型:即时工作记忆、情节记忆、程序性记忆和语义知识系统。通过基于文件的工作上下文记忆、模型上下文协议的数据库集成以及RAG系统等技术方案,满足不同记忆需求。此外,高级技术如动态示例选择、记忆蒸馏和冲突解决机制进一步提升系统智能化水平。总结指出,这些技术推动智能体向更接近人类认知的复杂记忆处理机制发展,为人工智能开辟新路径。
633 5
构建智能AI记忆系统:多智能体系统记忆机制的设计与技术实现
|
机器学习/深度学习 编解码 人工智能
【生成式对抗网络】GANs在数据生成、艺术创作,以及在增强现实和虚拟现实中的应用
生成对抗网络(Generative Adversarial Networks, GANs)在数据生成领域具有显著的应用价值。GANs通过生成器(Generator)和判别器(Discriminator)两个相互竞争的神经网络,不断迭代优化,从而生成高质量的数据样本。这一技术在数据增强方面尤为重要,特别是在数据稀缺或难以获取的领域,如医疗影像分析、自动驾驶等。GANs能够生成与真实数据相似的新数据样本,从而扩充数据集规模,提高模型的泛化能力。此外,GANs还可以用于生成仿真数据,如金融领域中的股票价格走势,用于训练预测模型,提高预测准确性
404 2
|
机器学习/深度学习 编解码 PyTorch
训练Sora模型,你可能需要这些(开源代码,模型,数据集及算力评估)
在之前的文章《复刻Sora有多难?一张图带你读懂Sora的技术路径》,《一文看Sora技术推演》我们总结了Sora模型上用到的一些核心技术和论文,今天这篇文章我们将整理和总结现有的一些开源代码、模型、数据集,以及初步训练的算力评估,希望可以帮助到国内的创业公司和个人开发者展开更深的研究。
|
人工智能 Python
模型评估与选择:避免过拟合与欠拟合
【7月更文第18天】在人工智能的探险旅程中,打造一个既聪明又可靠的模型可不简单。就好比在茫茫人海中找寻那位“知心朋友”,我们需要确保这位“朋友”不仅能在训练时表现优异,还要能在新面孔面前一样游刃有余。这就引出了模型评估与选择的关键议题——如何避免过拟合和欠拟合,确保模型既不过于复杂也不过于简单。今天,我们就来一场轻松的“模型相亲会”,通过交叉验证、混淆矩阵、ROC曲线这些实用工具,帮你的模型找到最佳伴侣。
501 2
|
安全 算法 关系型数据库
线程安全--深入探究线程等待机制和死锁问题
线程安全--深入探究线程等待机制和死锁问题
465 1
|
存储 安全 数据安全/隐私保护
网络信息安全基本属性
常见的网络信息安全基本属性主要有机密性、完整性、可用性、不可抵赖性和可控性等,其中机密性(Confidentiality)、完整性(Integrity)、可用性(Availability)被称为网络信息系统核心的CIA安全属性,此外还有其他的安全属性包括:真实性、时效性、合规性、隐私性等。
1169 0
|
网络协议 Java 关系型数据库
99%的人看了它都会说这是一篇很全的tomcat服务❤️❤️[⭐建议收藏⭐]
99%的人看了它都会说这是一篇很全的tomcat服务❤️❤️[⭐建议收藏⭐]
352 0
99%的人看了它都会说这是一篇很全的tomcat服务❤️❤️[⭐建议收藏⭐]
|
关系型数据库 MySQL C++
fatal error C1189: #error: STL1003: Unexpected compiler, expected C++ compiler
fatal error C1189: #error: STL1003: Unexpected compiler, expected C++ compiler
1127 0