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

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

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

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类定义的。
  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. #include <iostream>
  10. #include <string>
  11. using namespace std;
  12. int main()
  13. {
  14. string str("This is a simple demo !");
  15. for (string::size_type index = 0; index != str.size(); ++index)
  16. {
  17. cout << str[index];
  18. }
  19. cout << endl;
  20. return 0;
  21. }

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

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

  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. #include <iostream>
  10. #include <vector>
  11. using namespace std;
  12. int main()
  13. {
  14. vector<int> ivec;
  15. //vector::size_type
  16. for (vector<int>::size_type ix = 0 ; ix != 10; ++ix)
  17. {
  18. ivec.push_back(ix+1);
  19. }
  20. //vector::iterator
  21. for (vector<int>::iterator iter = ivec.begin();
  22. iter != ivec.end(); ++iter)
  23. {
  24. cout << *iter << "  ";
  25. }
  26. cout << endl;
  27. return 0;
  28. }
  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. #include <list>
  10. #include <iostream>
  11. using namespace std;
  12. int main( )
  13. {
  14. list <int> c1;
  15. list <int>::size_type i;
  16. c1.push_back( 1 );
  17. i = c1.size( );
  18. cout << "List length is " << i << "." << endl;
  19. c1.push_back( 2 );
  20. i = c1.size( );
  21. cout << "List length is now " << i << "." << endl;
  22. return 0;
  23. }
  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. #include <map>
  10. #include <iostream>
  11. int main()
  12. {
  13. using namespace std;
  14. map<int, int> m1, m2;
  15. map<int, int>::size_type i;
  16. typedef pair<int, int> Int_Pair;
  17. m1.insert(Int_Pair(1, 1));
  18. i = m1.size();
  19. cout << "The map length is " << i << "." << endl;
  20. m1.insert(Int_Pair(2, 4));
  21. i = m1.size();
  22. cout << "The map length is now " << i << "." << endl;
  23. return 0;
  24. }
    • size_t

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

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

      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. #include <iostream>
      10. #include <bitset>
      11. using namespace std;
      12. int main()
      13. {
      14. //bitvec有32位,每位都是0
      15. bitset<32> bitvec;
      16. cout << " bitvec : " << bitvec << endl;
      17. //count()统计bitvec中置1的个数
      18. size_t bitcount = bitvec.count();
      19. cout << "bitvec.count() :" << bitcount << endl;
      20. //size()统计bitvec二进制位的个数
      21. size_t bitsize = bitvec.size();
      22. cout << "bitvec.size() :" << bitsize << endl;
      23. return 0;
      24. }
    • differentce_type

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

    • ptrdiff_t

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

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

size_type、size_t、differentce_type以及ptrdiff_t的更多相关文章

  1. size_t 、wchar_t和 ptrdiff_t

    size_t在C语言中就有了. 它是一种"整型"类型,里面保存的是一个整数,就像int, long那样.这种整数用来记录一个大小(size).size_t的全称应该是size ty ...

  2. c++ ptrdiff_t 类型

    ptrdiff_t是C/C++标准库中定义的一个与机器相关的数据类型.ptrdiff_t类型变量通常用来保存两个指针减法操作的结果.ptrdiff_t定义在stddef.h(cstddef)这个文件内 ...

  3. size_t类型

    size_t在C语言中就有了.它是一种“整型”类型,里面保存的是一个整数,就像int, long那样.这种整数用来记录一个大小(size).size_t的全称应该是size type,就是说“一种用来 ...

  4. ptrdiff_t类型

    一.特性 1. 这是一种标准库类型 2. 是两个指针相减的结果的类型(因为差值可能为负值,所以是一种带符号类型) 3. 和size_t一样,ptrdiff_t也是一种定义在<cstddef> ...

  5. C++ std::array

    std::array template < class T, size_t N > class array; Code Example #include <iostream> ...

  6. 源码阅读笔记 - 2 std::vector (1)

    vector的源码真是太长了,今天用了一个下午和一个晚上看和注释了前面的一千行左右 p.s.博客园的代码高亮真是太垃圾, 如果想要阅读带注释的源码,推荐粘贴到VS2015里,然后按ctrl+z取消自动 ...

  7. C++基础内容复习

    下列语句定义了5个变量: int count; double sales_price,sum; std::string title; Sales_item bookItem; 每个定义都是以类型说明符 ...

  8. BitSet

    前几天干了一件比较无聊的事儿——抄了一遍C++ STL bitset的源代码,把不懂的宏定义去掉了,发现(暂时)还能用,嘿嘿. #ifndef BITSET_H #define BITSET_H #i ...

  9. [翻译] C++ STL容器参考手册(第一章 <array>)

    返回总册 本章节原文:http://www.cplusplus.com/reference/array/array/ 1. std::array (C++11支持) template < cla ...

随机推荐

  1. 几百万的数据,mysql快速高效创建索引

    有一个问题,一张表有3百万条记录,随着时间的增加,记录量会更多,此时查询速度很慢.在创建此表前没有未相应字段添加索引,所以此时需要为表添加索引.但是因为数据量大的原因,索引添加不成功,想了很多办法,终 ...

  2. O(1)时间内删除指定链表结点

    题目 给定单链表头指针和一个结点指针,定义一个函数在O(1)时间内删除该结点. 分析 对于上图实例链表(a)删除指针p有两种方式 思路1:(b)找到前一个指针pre,赋值pre->next = ...

  3. Makefile 快速入门

    Makefile 速成 标签: Makefile编译器 2015-06-06 18:07 2396人阅读 评论(1) 收藏 举报  分类: C/C++(132)  Linux & MAC(19 ...

  4. R语言学习笔记——Base Graphics

    做exploratory data annalysis的作业,差点被虐死了,R从头开始,边做边学,最后搞到一点多才弄完,还有一个图怎么画都不对,最后发现是数据读取的时候有问题. 用来画图的数据来自:h ...

  5. dojo 七 DOM dojo/dom

    官方教程:Dojo DOM Functions对dom的使用,需要引用包dojo/dom.1.获取节点,dom.byIdbyId中既可以传递一个字符串,也可以传递一个节点对象 require([&qu ...

  6. AngularJs-ui modal 传参数

    最近开始学习 AnjularJs: 看了两天项目的代码开始动手完成项目中的功能,碰到些问题记录下备忘:方便以后再碰到这样疑惑的coder. 参见 Angular-ui  modal 传递 header ...

  7. django-based blog- mezzanine

    django-based blog- mezzanine zinnia 博客 hydra  暴力破解

  8. poj - 2431 Expedition (优先队列)

    http://poj.org/problem?id=2431 你需要驾驶一辆卡车做一次长途旅行,但是卡车每走一单位就会消耗掉一单位的油,如果没有油就走不了,为了修复卡车,卡车需要被开到距离最近的城镇, ...

  9. gdb mysq

    1.找到mysqld的id [root@default-tpl ~]# ps aux|grep mysqldroot 5006 0.0 0.0 103252 796 pts/6 S+ 15:15 0: ...

  10. SQL计算实际工作日(天)及两个时间(工作日)间隔(小时)!

    Code highlighting produced by Actipro CodeHighlighter (freeware)-->去掉法定节假日(周六,周天)和指定节假日 USE [DBNa ...