前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >size_type、size_t、differentce_type以及ptrdiff_t

size_type、size_t、differentce_type以及ptrdiff_t

作者头像
猿人谷
发布2018-01-17 09:39:26
9090
发布2018-01-17 09:39:26
举报
文章被收录于专栏:猿人谷猿人谷猿人谷

目录(?)[-]

  1. size_type size_t different_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 plaincopy

/******************************************* 
 * this is a simple demo to test size_type 
 * 
 * Auther : Jerry.Jiang 
 * Date : 2011/08/20 
 * http://blog.csdn.net/jerryjbiao 
 * 
 *********************************************/ 
 
#include <iostream> 
#include <string> 
 
using namespace std;  
 
int main()  
{  
    string str("This is a simple demo !");  
 
 for (string::size_type index = 0; index != str.size(); ++index)  
    {  
        cout << str[index];  
    }  
    cout << endl;  
 
 return 0;  
}  

这里特别注意的是:任何存储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:

[cpp] view plaincopy

/******************************************* 
 * this is a simple demo to test vector::size_type 
 * 
 * Auther : Jerry.Jiang 
 * Date : 2011/08/20 
 * http://blog.csdn.net/jerryjbiao 
 * 
 *********************************************/ 
 
#include <iostream> 
#include <vector> 
 
using namespace std;  
 
int main()  
{  
    vector<int> ivec;  
 
 //vector::size_type  
 for (vector<int>::size_type ix = 0 ; ix != 10; ++ix)  
    {  
        ivec.push_back(ix+1);  
    }  
 
 //vector::iterator 
 for (vector<int>::iterator iter = ivec.begin();  
                               iter != ivec.end(); ++iter)  
    {  
        cout << *iter << "  ";  
    }  
 
    cout << endl;  
 return 0;  
}  
[cpp] view plaincopy
/******************************************* 
 * this is a simple demo to test list::size_type 
 * 
 * Auther : Jerry.Jiang 
 * Date : 2011/08/20 
 * http://blog.csdn.net/jerryjbiao 
 * 
 *********************************************/ 
 
#include <list> 
#include <iostream> 
 
using namespace std;  
 
int main( )  
{  
 
   list <int> c1;  
   list <int>::size_type i;  
 
   c1.push_back( 1 );  
   i = c1.size( );  
   cout << "List length is " << i << "." << endl;  
 
   c1.push_back( 2 );  
   i = c1.size( );  
   cout << "List length is now " << i << "." << endl;  
 
 return 0;  
}  

[cpp] view plaincopy

/******************************************* 
 * this is a simple demo to test map::size_type 
 * 
 * Auther : Jerry.Jiang 
 * Date : 2011/08/20 
 * http://blog.csdn.net/jerryjbiao 
 * 
 *********************************************/ 
 
#include <map> 
#include <iostream> 
 
int main()  
{  
 using namespace std;  
    map<int, int> m1, m2;  
    map<int, int>::size_type i;  
 typedef pair<int, int> Int_Pair;  
 
    m1.insert(Int_Pair(1, 1));  
    i = m1.size();  
    cout << "The map length is " << i << "." << endl;  
 
    m1.insert(Int_Pair(2, 4));  
    i = m1.size();  
    cout << "The map length is now " << i << "." << endl;  
 
 return 0;  
}  
/*********************************************** 
 * this is a simple demo to test bitset::size_t 
 * 
 * Auther : Jerry.Jiang 
 * Date : 2011/08/20 
 * http://blog.csdn.net/jerryjbiao 
 * 
 *********************************************/ 
 
#include <iostream> 
#include <bitset> 
 
using namespace std;  
 
int main()  
{  
 //bitvec有32位,每位都是0 
    bitset<32> bitvec;  
    cout << " bitvec : " << bitvec << endl;  
 
 //count()统计bitvec中置1的个数 
 size_t bitcount = bitvec.count();  
    cout << "bitvec.count() :" << bitcount << endl;  
 
 //size()统计bitvec二进制位的个数 
 size_t bitsize = bitvec.size();  
    cout << "bitvec.size() :" << bitsize << endl;  
 
 return 0;  
}  
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2013-08-17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • size_type
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档