stl源码剖析 详细学习笔记deque(1)
//--------------------------15/3/12----------------------------
deque
{
deque没有容量(capacity)观念,是动态分段的,没有reserve(保留)功能;
缓存区大小默认为,表示有bytes;
以map作为主控;
//map
{
map是连续的空间,每个元素称为节点(node),都是一个指针,指向另一段连续的线性空间,称为缓存区;
缓存区是deque的储存主体;
}
//class
{
>
class deque
{
typedef T value_type;
typedef value_type* pointer;
map_pointer map; //指向map,map时块连续空间
map(T**)
size_type map_size; //map内克容纳多少指针
};
}
//iteratoer
{
为了使deque看起来是连续的要重载++
--的运算符;
// struct __deque_iterator
{
template<class T,class Ref,class
Ptr,size_t BufSiz>
struct __deque_iterator
{ //未继承std::iterator(为什么)
typedef __deque_iterator<T,T&,T*,BufSiz> iterator;
typedef __deque_iterator<T,const T&,const T*,BufSiz> const_iterator;
static size_t buffer_size(){return __deque_buf_size(BufSiz,sizeof(T));}
typedef random_access_iterator_tag iterator_category;
typedef T value_type;
typedef Ptr pointer;
typedef Ref reference;
typedef size_t size_type;
typedef ptrdiff_t difference_type;
typedef T** map_pointer;
typedef __deque_iterator self;//(为什么,仅仅是为了方便?)
T* cur; //缓存区中的现行(current)元素
T* first; //缓存区的头
T* last; //尾
map_pointer node;//当前节点 T**
}
/*
原书的说法是错的!!!!!!
n==0 表示缓存区为系统默认大小,返回(512/sz)个(sz大小的)缓存区
(T<512 bytes, 512bytes==sz*(512/sz)),
或者1个(sizeof(T)大小的缓存区)(T>=512 bytes
n!=0 表示用户要自定义缓存区大小,直接返回n个(sizeof(T)大小)缓存区;
*/
inline size_t __deque_buf_size(size_t n,size_t sz)
{
? n : (sz < ? size_t(/sz)
: size_t());
}
//set_node用于跳过一个缓存区
void set_node(map_pointer new_node)
{
node=new_node; //把当前节点设置成new_node
first=*new_node; //把缓存区的头设置成*new_node
last=first+difference_type (buffer_size());//尾部
}
referenceoperator*()const {return *cur;)}
//取出的数据就是T( cur:{T*} -->> *cur:{T})
pointeroperator->()const{return &(operator*());}
//operator*():{T}-->>&(operator*()):{T*}
difference_typeoperator-(const self& x)const
{
/*
例子:
假设‘/’表示一个node 假设一个缓存区有8个‘#’也就是说buffer_size()为8
node -> ///// -> ####
(当前节点为第5个缓存区) (cur指向第4个元素)
x -> /// -> ###
(当前节点为第3个缓存区) (cur指向第3个元素)
4号缓存区: 5-3-1=1得到一个完整的缓存区 -->> 8*1个(T类型)(x1*x2)
5号缓存区: 4-1=3 得到3个(T类型) (x3)
3号缓存区: 9-3=6 得到6个(T类型)
(x4)
8+3+6=17;
分析:
x1=difference_type(buffer_size())
为一个缓存区的个数(T类型)
x2=(node - x.node - 1)
为本对象的node节点-目标对象的node节点的个数(缓存区)减1
x3=(cur - first) 为当前元素-这个缓存区第一个元素所得个数(T类型)
x4=(x.last - x.cur)
为目标对象node节点的最后元素-其当前元素所得的元素个数(T类型)
return value(假设有个返回值)==x1*x2+x3+x4;
*/
) +
(cur - first) + (x.last - x.cur);
}
stl源码剖析 详细学习笔记deque(1)的更多相关文章
- stl源码剖析 详细学习笔记deque(3)
protected: typedef simple_alloc<value_type,Alloc> data_allocator; //用来配置元素的alloc typedef simpl ...
- stl源码剖析 详细学习笔记deque(2)
//---------------------------15/3/13---------------------------- self&operator++() { ++cur; if(c ...
- stl源码剖析 详细学习笔记 hashtable
//---------------------------15/03/24---------------------------- //hashtable { /* 概述: sgi采用的是开链法完成h ...
- stl源码剖析 详细学习笔记 set map
// // set map.cpp // 笔记 // // Created by fam on 15/3/23. // // //---------------------------15/03 ...
- stl源码剖析 详细学习笔记 RB_tree (1)
// // RB_tree_STL.cpp // 笔记 // // Created by fam on 15/3/21. // // #include "RB_tree_STL.h&q ...
- stl源码剖析 详细学习笔记priority_queue slist
// // priority_queue.cpp // 笔记 // // Created by fam on 15/3/16. // // //------------------------- ...
- stl源码剖析 详细学习笔记heap
// // heap.cpp // 笔记 // // Created by fam on 15/3/15. // // //---------------------------15/03/15 ...
- stl源码剖析 详细学习笔记stack queue
// // stack.cpp // 笔记 // // Created by fam on 15/3/15. // // //---------------------------15/03/1 ...
- stl源码剖析 详细学习笔记 空间配置器
//---------------------------15/04/05---------------------------- /* 空间配置器概述: 1:new操作包含两个阶段操作 1>调 ...
随机推荐
- 在 Azure VM 中使用应用商店映像创建 HPC Pack 群集的头节点
使用 Azure 应用商店和 Azure 门户中的 Microsoft HPC Pack 2012 R2 虚拟机映像创建 HPC 群集的头节点. 此 HPC Pack VM 映像基于预安装了 HPC ...
- Oracle EBS OPM 子库存转移
--子库存转移 --created by jenrry DECLARE l_mtl_txn_rec mtl_transactions_interface%ROWTYPE; l_mtl_txn_lot_ ...
- 浅谈C#中的 async await 以及对线程相关知识的复习
C#5.0以后新增了一个语法糖,那就是异步方法async await,之前对线程,进程方面的知识有过较为深入的学习,大概知道这个概念,我的项目中实际用到C#异步编程的场景比较少,就算要用到一般也感觉T ...
- 【史上最全】申请配置阿里云服务器,并部署IIS和开发环境,项目上线经验
最近一年在实验室做web后端开发,涉及到一些和服务器搭建及部署上线项目的相关经验,写个帖子和小伙伴们分享,一同进步! 首先谈一下,为什么越来越多中小型公司/实验室,部署项目的趋势都是在云服务器而不是普 ...
- 一、JSP九大内置对象 二、JAVAEE三层架构和MVC设计模式 三、Ajax
一.JSP九大内置对象###<1>概念 不需要预先申明和定义,可以直接在jsp代码中直接使用 在JSP转换成Servlet之后,九大对象在Servlet中的service方法中对其进行定义 ...
- Mysql表类型(存储引擎)的比较
面试官问:你知道mysql有哪些存储引擎,区别是啥? 我:一脸闷逼,于是乎下来补一补,以作备查 1.和大多数数据库不同,MySQL 中有一个存储引擎的概念,针对不同的存储需求可以选择最优的存储引擎. ...
- Beyond Compare使用
1.通过过滤功能设置要比较的文件: 2.all,diff功能适用于文件本身的差异以及目录的差异 其它问题: 1.Beyond Compare比较文件时,相同的文件也显示为红色(有差异) http:// ...
- 10.Solr4.10.3数据导入(DIH全量增量同步Mysql数据)
转载请出自出处:http://www.cnblogs.com/hd3013779515/ 1.创建MySQL数据 create database solr; use solr; DROP TABLE ...
- PHP安全过滤函数
在PHP中,有些很有用的函数开源非常方便的防止你的网站遭受各种攻击,例如SQL注入攻击,XSS(Cross Site Scripting:跨站脚本)攻击等. 1. mysql_real_escap ...
- POJ 3415 Common Substrings 【长度不小于 K 的公共子串的个数】
传送门:http://poj.org/problem?id=3415 题意:给定两个串,求长度不小于 k 的公共子串的个数 解题思路: 常用技巧,通过在中间添加特殊标记符连接两个串,把两个串的问题转换 ...