cctype头文件中的一些内容

1. string 标准库

1.1初始化














string s1; 默认构造函数s1为空
string s2(s1); 将s2初始化为s1的一个副本
string s3(“value”); 将s3初始化为一个字符串字面值副本
string s4(n,’c’); 将s4初始化为字符’c’的n个副本

string对象的赋值:赋值所做的工作:必须先将s1所占的内存释放掉,然后在分配足够的内存,最后将新字符串赋值到s1中;

string对象和字符串字面值的连接:+操作符的左右操作数必须至少一个是string类型的。如果试图将两个字符串的字面值连接起来是不合法的。

string 类型通过下标操作符[] 来访问string对象中的单个字符。

string对象中字符的处理(下表中的所有函数都在cctype头文件中定义)












































isalnum(c) 如果c是字母或数字,则返回True
isalpha(c) 如果c是字母,则返回true
iscntrl(c) 如果c是控制字符,则返回true
isdigit(c) 如果c是数字,则返回true
isgraph(c) 如果c不是空格,但可打印,则为true
islower(c) 如果c是小写字母,则为true
isprint(c) 如果c是可打印字符,则为true
ispunct(c) 如果c是标点符号,则为true
isspace(c) 如果c是空白是否,则为true
isupper(c) 如果c是大写字母,则为true
isxdigit(c) 如果c是十六进制的数,则为true
tolower(c) 如果c是大写字母,返回其小写字母的形式,否则直接返回c
toupper(c) 如果c是小写字母,返回其大写字母的形式,否则直接返回c
   

空白字符是:空格、制表符、垂直制表符、回车符、换行符、进制符

标点符号:处数字、字母、可打印的空白符(空格)以外的其他字符。

建议:采用 C 标准库头文件的 C++ 版本

C++ 标准库除了定义了一些选定于 C++ 的设施外,还包括 C 标准库。 C++ 中的头文件 cctype 其实就是利用了 C 标准库函数,这些库函数就

       定义在 C 标准库的 ctype.h 头文件中。

C 标准库头文件命名形式为 name 而 C++ 版本则命名为 cname ,少了 后缀,.h 而在头文件名前加了 c 表示这个头文件源自 C
标准库。因此,
cctype 与 ctype.h 文件的内容是一样的,只是采用了更适合 C++程序 的形式。特别地,cname
头文件中定义的名字都定义在命名空间 std 内,
而 .h 版本中的名字却不是这样。

通常,C++ 程序中应采用 cname 这种头文件的版本,而不采 用 name.h 版本,这样,标准库中的名字在命名空间 std 中保持一致。 使用 .h
版本会给程序员带来负担,因为他们必须记得哪些标准库名字 是从 C 继承来的,而哪些是 C++ 所特有的。

2. 标准库vector类型

vecto是同一种类型的对象集合,每个对象都有一个对应的整数索引值,我们把vector成为容器。

#include <vector>

using std::vector;

vector是一个类模板,使用模板可以编写一个类的定义或函数的定义,而用于多个不同的数据类型。

定义vector<int> ivect

















初始化vector  
vector<T> v1 默认构造函数为空
vector<T>v2(v1) v2是v1的一个副本
vector<T>v3(n,i); v3是包含n个值为i的元素
vector<T>v4(n) v4含有值初始化的元素的n个副本

vector对象的重要属性就是可以再运行的时候高效的添加元素。

vector对象的操作:























v.empty() 如果为空,则返回true,否则返回false
v.size() 返回v中元素的个数
v.push_back(t) 在v的末尾增加一个值为t的元素
v[n] 返回v中位置为n的元素
v1=v2 把v1中的元素替换为v2中元素的副本
v1==v2 如果v1和v2相等,则返回true
!=,<,<=,>,>= 条件操作符

vector下标操作不添加元素。进能对已经存在的元素进行下标操作。

3.迭代器:是一种检查容器内元素并遍历元素的数据类型。每种容器类型都定义了自己的迭代器类型,如vector:

vector<int>::iterator iter;

每种容器都有一个begain和end的函数用于返回迭代器,如果容器中有元素的话,有begain返回迭代器指向的第一个元素。由end操作返回迭代器指向vector的“末尾元素的下一个”,如果vector为空,begain返回的迭代器和end返回的迭代器相同。由end操作返回的迭代器并不指向vector中的任何元素,相反,它只是起一个哨兵(sentinel)的作用,表示我们已经处理完vector中的所有元素。迭代器的解引用操作符返回返回迭代器所指向的元素。迭代器的自增操作符是把容器中的迭代器向前移动一个位置。迭代器的的操作==
和!=是比较两个迭代器,如果两个迭代器对象指向同一个元素,则他们相同,否则就不相等。

const_interator
每种容器懂定义了一种名为const_interator的类型,该类型只能读取容器内的元素,不能改变其值。他自身的值可以改变,但是其指向的元素的值是不能改变的。

迭代器的算术操作包括:iter+n   iter-n iter1-iter2

时间: 2024-09-30 10:47:03

cctype头文件中的一些内容的相关文章

cctype头文件(字符处理库)的使用

C++ 中cctype头文件的使用 头文件cctype(字符处理库)中定义了有关字符判断与处理的库函数,使用前要包含头文件: #include <cctype> using namespace  std: cctype头文件中的常用函数列表如下: 函数名称   返回值isalnum()  如果参数是字母数字,即字母或者数字,函数返回trueisalpha()  如果参数是字母,函数返回trueiscntrl()  如果参数是控制字符,函数返回trueisdigit()  如果参数是数字(0-9

[C++]关于头文件中的防卫式声明(#ifndef...#pragma once)

大家知道,我们写.h文件时,通常会加上防卫式声明,有以下两种方式: 1. 宏定义 #ifndef _FILENAME_ #define _FILENAME_ //... #endif 2. 编译器指令 #pragma once 但是,为什么头文件中需要添加这种防卫式声明呢?如果没有这样的声明,会出现怎样的问题.这里,先看一个例子. -- "Car.h",代码如下(并没有添加防卫式声明): // Car.h class Car { // ... }; -- "Person.h&

OC高效率52:(二)类的头文件中尽量少引用其他头文件

// //  EOCPerson.h //  OC高效率52:类的头文件中尽量少引用其他头文件 // //  Created by Zoujie on 15/10/8. //  Copyright ? 2015年 Zoujie. All rights reserved. // #import <Foundation/Foundation.h> //#import "EOCEmployer.h" @class EOCEmployer;//向前申明该类,将引入头文件的时机尽量延

浅谈c/c++头文件中#ifndef/#define/#endif的用法

想必很多人都看过“头文件中用到的 #ifndef/#define/#endif 来防止该头文件被重复引用”.但是是否能理解“被重复引用”是什么意思?头文件被重复引用了,会产生什么后果?是不是所有的头文件中都要加入#ifndef/#define/#endif 这些代码? 1. 其实“被重复引用”是指一个头文件在同一个cpp文件中被include了多次,这种错误常常是由于include嵌套造成的.如:存在a.h文件#include "c.h"而此时b.cpp文件导入了#include &q

c语言头文件中定义全局变量的问题

问题是这么开始的: 最近在看一个PHP的扩展源码,编译的时候的遇到一个问题: ld: 1 duplicate symbol for architecture x86_64 仔细看了一下源码,发现在头文件中 出现了全局变量的定义. 简化一下后,可以这么理解: // t1.h #ifndef T1_H #define T1_H int a = 0; #endif //------------------ //t1.c #include "t1.h" #include "t2.h&

c语言头文件中定义变量

最近在看一个PHP的扩展源码,编译的时候的遇到一个问题: ld: 1 duplicate symbol for architecture x86_64 仔细看了一下源码,发现在头文件中 出现了全局变量的定义 ZEND_DECLARE_MODULE_GLOBALS(xx) 简单开来,可以这么理解 // t1.h #ifndef T1_H #define T1_H int a = 0; #endif //------------------ //t1.c #include "t1.h" #

如何隐藏C++头文件中的实现

嗯,先从一个问题说起,游戏引擎中的贴图管理模块该如何实现?我们可以分别想象一下这个模块在C和C++中的大体实现.注意,为了简化,下面的代码仅仅是示意一下而已. 一. C 中的实现 C 通过头文件来暴露贴图模块的操作函数,texture.h 头文件代码如下: #pragma once //接口1:初始化贴图管理模块 void texture_init(); //接口2:加载一个贴图 void texture_load(int id); //接口3:销毁一个贴图 void texture_unloa

在类的头文件中尽量少引入其他头文件 &lt;&lt;Effective Objective-C&gt;&gt;

与C 和C++ 一样,Objective-C 也使用"头文件"(header file) 与"实现文件"(implementation file)来区隔代码.用Objective-C 语言编写"类"(class)的标准方式为:以类名做文件名,分别创建两个文件,头文件后缀用.h,实现文件后缀用.m.创建好一个类之后,其代码看上去如下所示: // EOCPerson.h #import <Foundation/Foundation.h>

C语言头文件中包含的函数

math.h常用函数 int  abs   (int x); double  acos  (double x); double  asin  (double x); double  atan  (double x); double  atan2 (double y, double x); double  atof  (const char *s); double  ceil  (double x); double  cos   (double x); double  cosh  (double