C++ Primer 第3章 字符串、向量和数组


3.1 命名空间的using声明

using namespace::name;

头文件不应包含using声明


3.2 标准库类型string

使用等号(=)初始化一个变量,实际上执行的是拷贝初始化,编译器把等号右侧的初始值拷贝到新创建的对象中去。如果不使用等号,则执行的是直接初始化

常用操作:

- getline(is,s)从is中读取一行赋给s,返回is

- s.empty()s为空返回true,否则返回false

- s.size()返回s中字符的个数

其中getline函数从给定的输入流中读取内容,直到遇到换行符为止(注意换行符也被读进来了),然后把所读的内容存入到string对象中(注意不存换行符)。如果输入的一开始就是换行符,那么所得的结果是个空string

触发getline函数返回的那个换行符实际上被丢弃掉了,得到的string对象中并不包含该换行符。

size()函数返回的类型是string::size_type类型,是无符号整型数,这体现了标准库类型与机器无关的特性。在C++11新标准中,允许编译器使用auto或者decltype来推断变量的类型。

由于是无符号整型数,所以不能和负数比,因为负数会自动转换成一个比较大的无符号值。

字符串字面值与string是不同的类型,字符串无法用加号相连。

cctype头文件中的函数:

isalnum(c)/isalpha(c)/iscntrl(c)/isdigit(c)/isgraph(c)/islower(c)

ispunct(c)/isspace(c)/isupper(c)/isxdigit(c)/tolower(c)/toupper(c)

在名为cname的头文件中定义的名字属于命名空间std,而定义在.h的头文件中则不然。

处理每个字符,使用基于范围的for语句

for (auto c : str)
cout << c << endl;

使用范围for语句改变字符串中的字符(使用引用)

for (auto &c : s)
c = toupper(c);
cout << s << endl;

string的下标运算符[]接受的是string::size_type的值,其他值会自动转换为无符号类型。


3.3 标准库类型vector

vector的size返回的类型是vector<type>::size_type

不能通过下标添加元素,正确的方法是使用push_back

超出下标范围会产生缓冲区溢出(buffer overflow)

确保下标合法的一种有效手段就是尽可能使用范围for语句。


3.4 迭代器介绍

vecotr<int>::iterator it;

string::iterator it2;

vector<int>::const_iterator it3; //只读

string::const_iterator it4; //只读

begin负责返回指向第一个元素的迭代器

end返回“尾元素的下一位置”的迭代器,是本不存在的“尾后”元素。

如果容器为空,则begin和end返回的是同一个迭代器,都是尾后迭代器。

  • *iter返回迭代器iter所指元素的引用
  • iter->mem解引用iter并获取该元素的名为mem的成员,等价于(*iter).mem
for (auto it = text.cbegin();
it != text.cend() && !it->empty(); ++it)
cout << *it << endl;

关键概念:泛型编程

C++程序员习惯性的在循环中使用!=,因为所有标准库容器都定义了==和!=,但是它们大多数都没有定义<运算符。因此,只要养成使用迭代器和!=的习惯,就不用太在意用的到底是哪种容器类型。

常量begin和end用v.cbegin()v.cend()获得

谨记,但凡是使用了迭代器的循环体,都不要向迭代器所属的容器添加元素,这样会使迭代器失效。

两个迭代器相减的结果是它们之间的距离

距离类型是difference_type,是带符号整数型

取中间:auto mid = vi.begin() + vi.size() / 2;

使用迭代器完成二分查找:

auto beg = text.begin(), end = text.end();
auto mid = text.begin() + (end - beg)/2;
while (mid != eend && *mid != sought){
if (sought < *mid)
end = mid;
else
beg = mid + 1;
mid = beg + (end - beg)/2;
}

3.5 数组

定义

  • 数组可使用定义为constexpr的函数来指定大小。
  • 数组无法使用auto关键字
  • 数组的元素应为对象
  • 数组不允许拷贝给其他数组作为初始值,也不能为其他数组赋值

指向数组的指针和引用

int (*Parray) [10] = &arr;
int (&arrRef) [10] = arr;

访问数组元素

在使用数组下标的时候,通常将其定义位size_t类型,这是一种机器相关的无符号类型,它被设计的足够大以便能表示内存中任意对象的大小。在cstddef头文件中定义了size_t类型,这个文件是stddef.h的C++版本。

将数组初始化为0:unsigned scores[11] = {};

指针和数组

在很多用到数组名字的地方,编译器都会自动的将其转换位一个指向数组首元素的指针;意味着用auto时,初始化为数组时,其实是指向数组首元素的指针。二decltype返回的类型是数组,数组大小和原数组一致。

指针也是迭代器

我们可使用不存在的元素地址作为尾后指针

int *e = &arr[10];
for (int *b = arr; b != e; ++b)
cout << *b << endl;

C++11中为了避免出错引入了begin和end标准库函数,用数组名作为它们的参数。这两个函数定义在iterator头文件中

// Find first negative number.
int *pbeg = begin(arr), *pend = end(arr);
while (pbeg != pend && *pbeg >=0)
++pbeg;

两个指针相减的结果类型是一种名为ptrdiff_t的标准库类型,和size_t一样,也是一种定义在cstddef头文件中的机器相关的类型。因为差值可能位负值,所以ptrdiff_t是一种带符号类型。对于空指针同样适用

与旧代码的接口

string对象有c_str()方法为字符数组赋值:

const char *str = s.c_str();

使用数组初始化vector对象:

vector<int> ivec(begin(int_arr), end(int_arr));


3.6 多维数组

对于二维数组来说,常把第一个维度称作行,第二个维度称作列。

用花括号初始化每行元素:

int ia[3][4] = {{ 0 }, { 4 }, { 8 }};

使用范围for语句处理多维数组

size_t cnt = 0;
for (auto &row : ia)
for (auto &col :row){
col = cnt;
++cnt ;
}

使用标准库函数begin和end也能实现:

for (auto p = begin(ia); p != end(ia); ++p){
for (auto q = begin(*p); q != end(*p); ++q)
cout << *q << ' ';
cout << endl;
}

将4个整数组成的数组命名位int_array:

using int_array = int[4];
typedef int int_array[4];

C++ Primer 第3章 字符串、向量和数组的更多相关文章

  1. <<C++ Primer>> 第三章 字符串, 向量和数组 术语表

    术语表 第 3 章 字符串, 向量和数组 begin: 是 string 和 vector 的成员,返回指向第一个元素的迭代器.也是一个标准库函数,输入一个数字,返回指向该数字首元素的指针.    缓 ...

  2. [C++ Primer] 第3章: 字符串, 向量和数组

    标准库类型string string初始化 string s2(s1); string s2 = s1; string s3("value"); string s3 = " ...

  3. PHP:第五章——字符串与数组及其他函数

    <?php header("Content-Type:text/html;charset=utf-8"); //1.str_split——将字符串转换为数组. /*$str= ...

  4. 《汇编语言 基于x86处理器》第九章字符串与数组部分的代码

    ▶ 书中第九章的程序,主要讲了字符串相关的输入.输出,以及冒泡排序.二分搜索 ● 代码,Irvine32 中的字符串库函数代码范例 INCLUDE Irvine32.inc .data str1 BY ...

  5. C++ Primer 5th 第3章 字符串、向量和数组

    *****代码在Debian g++ 5.40 / clang++ 3.8(C++11)下编写调试***** 本章主要是关于字符串.数组的内容,以及一些简单的容器知识. 1.using的声明 usin ...

  6. perl5 第四章 列表和数组变量

    第四章 列表和数组变量 by flamephoenix 一.列表二.数组--列表的存贮  1.数组的存取  2.字符串中的方括号和变量替换   3.列表范围  4.数组的输出  5.列表/数组的长度  ...

  7. 《C#从现象到本质》读书笔记(五)第5章字符串第6章垃圾回收第7章异常与异常处理

    <C#从现象到本质>读书笔记(五)第5章字符串 字符串是引用类型,但如果在某方法中,将字符串传入另一方法,在另一方法内部修改,执行完之后,字符串的只并不会改变,而引用类型无论是按值传递还是 ...

  8. C++ Primer 第2章 变量和基本类型

    C++ Primer 第2章 变量和基本类型 C Primer 第2章 变量和基本类型 1 基本内置类型 算数类型 类型转换 字面值常量 2 变量 变量定义 3 复合类型 引用d左引用 指针d 4 c ...

  9. sizeof、strlen、字符串、数组,整到一块,你还清楚吗?

    写在前面 sizeof.strlen.字符串.数组,提到这些概念,相信学过C语言的人都能耳熟能详,也能谈得头头是道,但是,在实际运用中,当这些内容交织在一起时,大家却不一定能搞地清清楚楚,本文的目的正 ...

随机推荐

  1. Jmeter文件目录,功能简介

    1.Jmeter文件目录:1)bin文件: Jmeter启动:bin/jmeter.bat Jmeter日志文件:jmeter.log Linux的启动文件:Jmeter.sh Jmeter系统配置文 ...

  2. ubuntu 报错E: Could not get lock /var/lib/dpkg/lock-frontend - open (11: Resource temporarily unav E: Unable to acquire the dpkg frontend lock (/var/lib/dpkg/lock-frontend), is another process us

    1.配置xshell,查看虚拟机中ubuntu中网络ip ifconfig 报错 Command 'ifconfig' not found, but can be installed with: su ...

  3. BIO与NIO

    BIO与NIO 1.传统BIO (1)特点 面向数据流 阻塞式传输 一个客户端对应一个线程 在客户机增多的情况下,线程资源随之增多,会造成cpu资源枯竭 (2)需求 ​ 客户机向服务器输出字符串,逐一 ...

  4. VS2013使用自带的数据库 Microsoft SQL Server 2012 Express LocalDB

    注:DeptLocalDB:自己取的数据库实例名称 DeptSharedLocalDB:自己取的实例共享名称np:\\.\pipe\LOCALDB#SH7C6ED5\tsql\query:命名管道名称 ...

  5. python--Pandas(一)

    一.Pandas简介 1.Python Data Analysis Library 或 pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的.Pandas 纳入了大量库和一 ...

  6. 用php读取xml数据

    parser是php内置的一个用来处理xml的解析器,它的工作由三个事件组成:起始标签. 读取数据.结束标签. 也就是说在对xml进行处理的时候每当遇到起始标签.数据和结束标签的时候函数会做相应的动作 ...

  7. 学习python第十三天,函数5 装饰器decorator

    定义:装饰器本质是函数,(装饰其他函数)就是为其他函数添加附加功能原则:1.不能修改被装饰的函数的源代码 2.不能修改装饰的函数的调用方式 实现装饰器知识储备1函数即变量2.高阶函数,满足2个条件之一 ...

  8. source tree 使用心得

    SourceTree 是 Windows 和Mac OS X 下免费的 Git 和 Hg 客户端管理工具,同时也是Mercurial和Subversion版本控制系统工具.支持创建.克隆.提交.pus ...

  9. 交互式的Bourne shell

    简介 当以交互的方式使用命令行时,shell有一些特殊的内置变量,这些变量中包含一系列选项.如果在选项中包含字母i,则表示shell以交互方式运行. # case "$-" in ...

  10. [Codeforces958A2]Death Stars (medium)(字符串+hash)

    Description 题目链接 Solution 这里用类似hash的方法将判断2个矩阵是否相同的时间降为O(m),总时间复杂度为O(m3) Code #include <cstdio> ...