| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> C++知识库 -> C++(指针、引用、STL) -> 正文阅读 |
|
[C++知识库]C++(指针、引用、STL) |
对象的定义:对象是指一块能存储数据并具有某种类型的内存空间 一个对象a,它有值和地址;运行程序时,计算机会为该对象分配存储空间,来存储该对象的值,通过该对象的地址,来访问存储空间中的值。 指针、引用指针类型名 * 指针变量名; 每个变量都被存放在从某个内存地址(以字节为单位)开始的若干个字节中;"指针",也称作"指针变量",大小为4个字节(或8个字节)的变量,其内容代表一个内存地址;通过指针,能够对该指针指向的内存区域进行读写。
指针的作用? 使用指针,就有自由访问内存空间的手段 不需要通过变量,就能对内存直接进行操作。通过指针,程序能访问的内存区域就不仅限于变量所占据的数据区域。 指针的相互赋值 不同类型的指针,如果不经过强制类型转换,不能直接互相赋值。 指针的运算
空指针? 地址0不能访问。指向地址0的指针就是空指针 可以用"NULL"关键字对任何类型的指针进行赋值。NULL实际上就是整数0,值为NULL的指针就是空指针
指针作为函数参数(形参是实参的一个拷贝) 指针和数组 数组的名字是一个指针常量(指向数组的起始地址)
作为函数形参时,T *p和 T p[]等价
引用类型名 & 引用名 = 某变量名;(定义了一个引用,将其初始化为引用某个变量)
某个变量的引用,等价于这个变量,相当于该变量的一个别名
引用作为函数的返回值
常引用 定义引用时,前面加const关键字,即为"常引用"
常引用和非常引用的转换 const T &和 T &是不同的类型,T &类型的引用或T类型的变量可以用来初始化const T &类型的引用;const T类型的常变量和const T &类型的引用则不能用来初始化T &类型的引用。 参考: STLSTL中六大组件容器(Container),一种数据结构(包含一组元素或元素集合的对象),基本容器:向量(vector), 双端队列(deque), 列表(list), 集合(set), 多重集合(multiset), 映射(map), 多重映射(multimap)。 序列式容器(Sequence containers),其中每个元素均有固定位置--取决于插入时机和地点,和元素值无关(vector, deque, list) 关联式容器(Associative containers),元素位置取决于特定的排序准则以及元素值,和插入次序无关(set, multiset, map, multimap) 迭代器(Iterator) 迭代器Iterator,用来在一个对象集群(collection of objects)的元素上进行遍历。这个对象集群或许是一个容器,或许是容器的一部分。迭代器的主要好处是,为所有容器提供了一组很小的公共接口。迭代器以++进行累进,以*进行提领,因而类似于指针,可以将其视为一种smart pointer。 例如++操作可以遍历至集群内的下一个元素。至于如何完成,取决于容器内部的数据组织形式。 每种容器都提供自己的迭代器,而这些迭代器能够了解容器内部的数据结构 算法(Algorithm) 用来处理群集内的元素。它们可以出于不同的目的而搜寻、排序、修改、使用那些元素。通过迭代器的协助,我们可以只需编写一次算法,就可以将它应用于任意容器,这是因为所有的容器迭代器都提供一致的接口。 仿函数(Functor) 适配器(Adaptor) 提供三种顺序容器适配器:queue(FIFO队列),priority_queue(优先级队列),stack(栈)。 适配器对容器进行包装,使其表现出另外一种行为。倘若要使用适配器,需要加入头文件 分配器(Allocator) 常用容器用法介绍vector 一个数组必须有固定的长度,在开数组的时候,此长度就被静态地确定下来。但vector却是数组的"加强版",vector理解为一个"变长数组" 事实上,vector的实现方式是基于倍增思想的:假如vector的实际长度为n,m为vector当前的最大长度,那么在加入一个元素的时候,先看一下,假如当前的n=m,则再动态申请一个2m大小的内存。反之,在删除的时候,如果n≥m/2,则再释放一半的内存。
vec.begin(), vec.end()? ? ? ? 返回vector的首尾迭代器 vec.front(), vec.back()? ? ? ? 返回vector的首尾元素 vec.push_back()? ? ? ? ? ? ? ? 从vector末尾加入一个元素 vec.size()? ? ? ? 返回vector当前的长度(大小) vec.pop_back()? ? ? ? 从vector末尾删除一个元素 vec.empty()? ? ? ? 返回vector是否为空,1为空,0不为空 vec.clear()? ? ? ? 清空vector? ? ? ? ? ? ? vector容器是支持随机访问的,可以像数组一样用[]取值。? ?
vector修改值?
deque(双端队列)
q.begin(), q.end()? ? ? ? 返回deque的首尾迭代器 q.front(), q.back()? ? ? ? 返回deque的首尾元素 q.push_back()? ? ? ? 从队尾入队一个元素 q.push_front()? ? ? ? 从队头入队一个元素 q.pop_back()? ? ? ? 从队尾出队一个元素 q.pop_front()? ? ? ? 从队头出队一个元素 q.size()? ? ? ? 队列中元素个数 q.clear()? ? ? ? 清空队列 deque支持随机访问,可以像数组下标一样取出其中的一个元素。即q[i] deque容器可以被应用到SPFA算法的SLF优化:SPFA算法的优化方式 set set满足互异性,set集合中的元素是默认升序的(set容器自动有序和快速添加、删除的性质是由其内部实现:红黑树(平衡树的一种))
s.empty()? ? ? ? 返回集合是否为空,是为1,否为0 s.size()? ? ? ? 返回当前集合的元素个数 s.clear()? ? ? ? 清空当前集合 s.begin(), s.end()? ? ? ? 返回集合的首尾迭代器(迭代器是一种指针。这里需要注意的是,由于计算机区间“前闭后开”的结构,begin()函数返回的指针指向的的确是集合的第一个元素。但end()返回的指针却指向了集合最后一个元素后面一个元素。)? s.insert(k)? ? ? ? 集合中加入元素k s.erase(k)? ? ? ? 集合中删除元素k s.find(k)????????返回集合中指向元素k的迭代器。如果不存在这个元素,就返回s.end(),这个性质可以用来判断集合中有没有这个元素。 s.lower_bound()? ? ? ? 返回集合中第一个大于等于关键字的元素 s.upper_bound()? ? ? ? 返回集合中第一个严格大于关键字的元素 multiset(有序多重集合) s.erase(k)? ? ? ? erase(k)函数在set容器中表示删除集合中元素k。但在multiset容器中表示删除所有等于k的元素。 倘若只删除这些元素中的一个元素
s.count(k)? ? ? ? count(k)函数返回集合中元素k的个数,为multiset所独有。? map 可以根据键值快速地找到这个映射出的数据, map容器的内部实现是一棵红黑树
mp.begin(), mp.end()? ? ? ? 返回首尾迭代器? mp.clear()? ? ? ? 清空函数操作 mp.size()? ? ? ? 返回容器大小 queue(FIFO)
q.front(), q.back()? ? ? ? 返回queue的首尾元素 q.push()? ? ? ? 从queue末尾加入一个元素 q.size()? ? ? ? 返回queue当前的长度(大小) q.pop()? ? ? ? 从queue队首删除一个元素 q.empty()? ? ? ? 返回queue是否为空,1为空,0不为空 priority_queue 优先队列在队列的基础上,将其中的元素加以排序。其内部实现是一个二叉堆。优先队列即为将堆模板化,将所有入队的元素排成具有单调性的一队,方便我们调用。 大根堆声明就是将大的元素放在堆顶的堆。优先队列默认实现的就是大根堆。 小根堆声明就是将小的元素放在堆顶的堆。
q.top()? ? ? ? 返回priority_queue的首元素 q.push()? ? ? ? 向priority_queue中加入一个元素 q.size()? ? ? ? 返回priority_queue当前的长度(大小) q.pop()? ? ? ? 从priority_queue末尾删除一个元素 q.empty()? ? ? ? 返回priority_queue是否为空,1为空,0不为空? stack(栈)
st.top()? ? ? ? 返回stack的栈顶元素 st.push()? ? ? ? 从stack栈顶加入一个元素 st.size()? ? ? ? 返回stack当前的长度(大小) st.pop()? ? ? ? 从stack栈顶弹出一个元素 st.empty()? ? ? ? 返回stack是否为空,1为空,0不为空 string(字符串操作) 其实string容器就是一个字符串
重载运算符C++语言中已经给出的运算符(算数运算符和逻辑运算符)只是针对C++语言中已经给定的数据类型进行运算。倘若我们想要对我们自定义数据类型进行运算的话,则需要重载运算符,我们可以把重载运算符理解为对已有的运算符的一种重新定义。 重载运算符的实现
|
|
C++知识库 最新文章 |
【C++】友元、嵌套类、异常、RTTI、类型转换 |
通讯录的思路与实现(C语言) |
C++PrimerPlus 第七章 函数-C++的编程模块( |
Problem C: 算法9-9~9-12:平衡二叉树的基本 |
MSVC C++ UTF-8编程 |
C++进阶 多态原理 |
简单string类c++实现 |
我的年度总结 |
【C语言】以深厚地基筑伟岸高楼-基础篇(六 |
c语言常见错误合集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/10 10:57:55- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |