二 迭代器(四)迭代器相应型别及traits编程技法

本文探讨了C++中迭代器的五种关键响应型别,包括value_type、difference_type、pointer、reference和iterator_category,并解释了它们在STL中的作用。此外,介绍了traits编程技法,特别是iterator_traits结构体,用于萃取迭代器特性。SGI STL的_type_traits扩展了这一概念,用于判断类型特性,以优化内存管理和操作效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

迭代器相应的型别

如果你希望你所开发的容器能够与STL水乳交融,一定要为你的容器的迭代器定义这五种相应型别。

(一) 根据经验,最常用到的迭代器相应型别有五种:

(1)value_type:

是指迭代器所指对象的类型。

(2)difference_type:

用来表示两个迭代器之间的距离,因此它也可以用来表示一个容器的最大容量,因为对于连续空间的容器,头尾之间的距离就是其最大容量。

(3)pointer:

(4)reference:

(5)iterator_category:

迭代器根据移动特性和实施操作,可以分为五类:input iterator、output iterator、forward iterator、bidirectional iterator和Random Access Iterator。例如:advance()和distance()要用到这个特性。


二 traits编程技法:

traits编辑技法大量应用于STL实现品中。它利用“内嵌型别”的编程技巧与编译器的template参数推导功能,增强c++未能提供的关于型别认证方面的能力。


(一)iterator_traits(特性萃取机):


template<class I>

struct iterator_traits{//特性萃取机

typedef  typename I::iterator_category iterator_category;

typedef  typename I::value_type value_type;

typedef  typename I::difference_type difference_type;

typedef  typename I::pointer pointer;

typedef  typename I::reference     reference;

};

下图说明,traits所扮演的“特性萃取机”的角色:


(2) Iterator源代码(stl_iterator_base_types.h):

mingw中iterator定义在stl_iterator_base_types.h头文件中,advance和distance函数定义在stl_iterator_base_funcs.h头文件中,stl_iterator.h中定义了insert iterator和reverse iterator。

以下是书中代码,略有不同:

1.五种迭代器特性和泛化的iterator_traits:


2.针对原始指针的而设计的traits特化版:


3. 返回迭代器类型的函数:


4 advance和distance函数:


(二) SGI STL的私房菜:_ _type_traits


(1)STL只对迭代器加以规范,制定出iterator_traits。SGI扩大了traits编程技法,于是有了_ _type_traits。

iterator_traits负责萃取迭代器的特性,_ _type_traits负责萃取型别的特性。


此处我们关注的型别的特性是指:

这个型别收是否具有non-trivial default constructor?

是否具有non-trivial copy constructor?

是否具有non-trivial assignment operator?

是否具有non-trivial destructor?

如果答案是否定的,那么久可以采用最有效率的措施。(例如根本不调用那些身居高位,不谋事是的那些constructor,destructor,而是采用内存直接处理操作如:malloc()、memcpy()...等等)。


(2)_ _type_traits定义的类型:

类型true_type: struct   _true_type{}

类型false_type:struct  _false_type{}


...



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值