字符型存储
|-------------|-------------|--------------|----------------------------------------------|--------------------|
| ASCII码表格 |||||
| 二进制 | 十进制 | 十六进制 | 字符/缩写 | 解释 |
| 00000000 | 0 | 00 | NUL (NULL) | 空字符 |
| 00000001 | 1 | 01 | SOH (Start Of Headling) | 标题开始 |
| 00000010 | 2 | 02 | STX (Start Of Text) | 正文开始 |
| 00000011 | 3 | 03 | ETX (End Of Text) | 正文结束 |
| 00000100 | 4 | 04 | EOT (End Of Transmission) | 传输结束 |
| 00000101 | 5 | 05 | ENQ (Enquiry) | 请求 |
| 00000110 | 6 | 06 | ACK (Acknowledge) | 回应/响应/收到通知 |
| 00000111 | 7 | 07 | BEL (Bell) | 响铃 |
| 00001000 | 8 | 08 | BS (Backspace) | 退格 |
| 00001001 | 9 | 09 | HT (Horizontal Tab) | 水平制表符 |
| 00001010 | 10 | 0A | LF/NL(Line Feed/New Line) | 换行键 |
| 00001011 | 11 | 0B | VT (Vertical Tab) | 垂直制表符 |
| 00001100 | 12 | 0C | FF/NP (Form Feed/New Page) | 换页键 |
| 00001101 | 13 | 0D | CR (Carriage Return) | 回车键 |
| 00001110 | 14 | 0E | SO (Shift Out) | 不用切换 |
| 00001111 | 15 | 0F | SI (Shift In) | 启用切换 |
| 00010000 | 16 | 10 | DLE (Data Link Escape) | 数据链路转义 |
| 00010001 | 17 | 11 | DC1/XON (Device Control 1/Transmission On) | 设备控制1/传输开始 |
| 00010010 | 18 | 12 | DC2 (Device Control 2) | 设备控制2 |
| 00010011 | 19 | 13 | DC3/XOFF (Device Control 3/Transmission Off) | 设备控制3/传输中断 |
| 00010100 | 20 | 14 | DC4 (Device Control 4) | 设备控制4 |
| 00010101 | 21 | 15 | NAK (Negative Acknowledge) | 无响应/非正常响应/拒绝接收 |
| 00010110 | 22 | 16 | SYN (Synchronous Idle) | 同步空闲 |
| 00010111 | 23 | 17 | ETB (End of Transmission Block) | 传输块结束/块传输终止 |
| 00011000 | 24 | 18 | CAN (Cancel) | 取消 |
| 00011001 | 25 | 19 | EM (End of Medium) | 已到介质末端/介质存储已满/介质中断 |
| 00011010 | 26 | 1A | SUB (Substitute) | 替补/替换 |
| 00011011 | 27 | 1B | ESC (Escape) | 逃离/取消 |
| 00011100 | 28 | 1C | FS (File Separator) | 文件分割符 |
| 00011101 | 29 | 1D | GS (Group Separator) | 组分隔符/分组符 |
| 00011110 | 30 | 1E | RS (Record Separator) | 记录分离符 |
| 00011111 | 31 | 1F | US (Unit Separator) | 单元分隔符 |
| 00100000 | 32 | 20 | (Space) | 空格 |
| 00100001 | 33 | 21 | ! | |
| 00100010 | 34 | 22 | " | |
| 00100011 | 35 | 23 | # | |
| 00100100 | 36 | 24 | $ | |
| 00100101 | 37 | 25 | % | |
| 00100110 | 38 | 26 | & | |
| 00100111 | 39 | 27 | ' | |
| 00101000 | 40 | 28 | ( | |
| 00101001 | 41 | 29 | ) | |
| 00101010 | 42 | 2A | * | |
| 00101011 | 43 | 2B | + | |
| 00101100 | 44 | 2C | , | |
| 00101101 | 45 | 2D | - | |
| 00101110 | 46 | 2E | . | |
| 00101111 | 47 | 2F | / | |
| 00110000 | 48 | 30 | 0 | |
| 00110001 | 49 | 31 | 1 | |
| 00110010 | 50 | 32 | 2 | |
| 00110011 | 51 | 33 | 3 | |
| 00110100 | 52 | 34 | 4 | |
| 00110101 | 53 | 35 | 5 | |
| 00110110 | 54 | 36 | 6 | |
| 00110111 | 55 | 37 | 7 | |
| 00111000 | 56 | 38 | 8 | |
| 00111001 | 57 | 39 | 9 | |
| 00111010 | 58 | 3A | : | |
| 00111011 | 59 | 3B | ; | |
| 00111100 | 60 | 3C | < | |
| 00111101 | 61 | 3D | = | |
| 00111110 | 62 | 3E | > | |
| 00111111 | 63 | 3F | ? | |
| 01000000 | 64 | 40 | @ | |
| 01000001 | 65 | 41 | A | |
| 01000010 | 66 | 42 | B | |
| 01000011 | 67 | 43 | C | |
| 01000100 | 68 | 44 | D | |
| 01000101 | 69 | 45 | E | |
| 01000110 | 70 | 46 | F | |
| 01000111 | 71 | 47 | G | |
| 01001000 | 72 | 48 | H | |
| 01001001 | 73 | 49 | I | |
| 01001010 | 74 | 4A | J | |
| 01001011 | 75 | 4B | K | |
| 01001100 | 76 | 4C | L | |
| 01001101 | 77 | 4D | M | |
| 01001110 | 78 | 4E | N | |
| 01001111 | 79 | 4F | O | |
| 01010000 | 80 | 50 | P | |
| 01010001 | 81 | 51 | Q | |
| 01010010 | 82 | 52 | R | |
| 01010011 | 83 | 53 | S | |
| 01010100 | 84 | 54 | T | |
| 01010101 | 85 | 55 | U | |
| 01010110 | 86 | 56 | V | |
| 01010111 | 87 | 57 | W | |
| 01011000 | 88 | 58 | X | |
| 01011001 | 89 | 59 | Y | |
| 01011010 | 90 | 5A | Z | |
| 01011011 | 91 | 5B | [ | |
| 01011100 | 92 | 5C | \ | |
| 01011101 | 93 | 5D | ] | |
| 01011110 | 94 | 5E | ^ | |
| 01011111 | 95 | 5F | _ | |
| 01100000 | 96 | 60 | ` | |
| 01100001 | 97 | 61 | a | |
| 01100010 | 98 | 62 | b | |
| 01100011 | 99 | 63 | c | |
| 01100100 | 100 | 64 | d | |
| 01100101 | 101 | 65 | e | |
| 01100110 | 102 | 66 | f | |
| 01100111 | 103 | 67 | g | |
| 01101000 | 104 | 68 | h | |
| 01101001 | 105 | 69 | i | |
| 01101010 | 106 | 6A | j | |
| 01101011 | 107 | 6B | k | |
| 01101100 | 108 | 6C | l | |
| 01101101 | 109 | 6D | m | |
| 01101110 | 110 | 6E | n | |
| 01101111 | 111 | 6F | o | |
| 01110000 | 112 | 70 | p | |
| 01110001 | 113 | 71 | q | |
| 01110010 | 114 | 72 | r | |
| 01110011 | 115 | 73 | s | |
| 01110100 | 116 | 74 | t | |
| 01110101 | 117 | 75 | u | |
| 01110110 | 118 | 76 | v | |
| 01110111 | 119 | 77 | w | |
| 01111000 | 120 | 78 | x | |
| 01111001 | 121 | 79 | y | |
| 01111010 | 122 | 7A | z | |
| 01111011 | 123 | 7B | { | |
| 01111100 | 124 | 7C | | | |
| 01111101 | 125 | 7D | } | |
| 01111110 | 126 | 7E | ~ | |
| 01111111 | 127 | 7F | DEL (Delete) | 删除 |
每个字符在计算机中都有相对应的ASCII码值
在char型中,取值范围为-128~127
若字符的ASCII码值超出这个范围,将会发生类型溢出
若是想要避免类型溢出,可以将取值范围改为0~256
即使用unsigned char进行命名字符,可以避免存储时的类型溢出
字符常量区分大小写,且对于字符进行命名时要用单引号括住
转义字符
当我们进行数据输出时,偶尔会碰到某个字符自动与printf中所用到的其他字符自动匹配从而导致无法正确输出或者输出效果与理想不符的情况出现,我们在这时就可以用字符转义序列
|-------|-----------------------|--------------|
| 转义字符 | 意义 | ASCII码值(十进制) |
| \a | 响铃(BEL) | 007 |
| \b | 退格(BS) ,将当前位置移到前一列 | 008 |
| \f | 换页(FF),将当前位置移到下页开头 | 012 |
| \n | 换行(LF) ,将当前位置移到下一行开头 | 010 |
| \r | 回车(CR) ,将当前位置移到本行开头 | 013 |
| \t | 水平制表(HT) (跳到下一个TAB位置) | 009 |
| \v | 垂直制表(VT) | 011 |
| \\ | 代表一个反斜线字符''\' | 092 |
| \' | 代表一个单引号(撇号)字符 | 039 |
| \" | 代表一个双引号字符 | 034 |
| \? | 代表一个问号 | 063 |
| \0 | 空字符(NUL) | 000 |
| \ddd | 1到3位八进制数所代表的任意字符 | 三位八进制 |
| \xhh | 十六进制所代表的任意字符 | 十六进制 |
实例
输出"I'm your father!!!"
printf("\"I\'m your father!!!\"");
字符型的输入
1.单个字符输入提前结束
scanf与getchar都可以用来对于单个字符的输入
但是当遇到一行输入多个字符时
我们的输入常常与理想状况不符
一般表现为提前结束输入
这是因为电脑自动读入的我们输入数据时分隔数据所用的空格
因此可以在%c与%c之间加上空格就能够解决这个问题
char a,b,c;
scanf("%c %c %c",&a,&b,&c);
2.首先读入整数再输入字符
方法一:输入n值后,使用getchar();来吸收空格
char a;
int n;
scanf("%d",&n);
getchar();
scanf("%c",&a);
方法二:使用赋值抑制符抑制空格的输入
char a;
int n;
scanf("%d",&n);
scanf("%*c%c",&a);
方法三:在scanf的输入过程中加入空格符
char a;
int n;
scanf("%d",&n);
scanf(" %c",&a);
对于字符和字符串进行处理的函数
由文章开头的ACSII码值表可以得出结论:
在十进制中大写字母的ASCII码值加32即为小写字母的ASCII码值
因此出现的手动转换的方式
if(a>='A'&&a<='Z')
{
a=a+32;//大写字母转换为小写字母
}
if(a>='a'&&a<='z')
{
a=a-32;//小写字母转换为大写字母
}
当然,也有专门处理字符类型的函数存在
在预处理时要添加#include<ctype.h>
|--------------------------------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| 单字节 | 宽字节 | 描述 |
| isalnum | iswalnum | 是否为字母数字 |
| isalpha | iswalpha | 是否为字母 |
| islower | iswlower | 是否为小写字母 |
| isupper | iswupper | 是否为大写字母 |
| isdigit | iswdigit | 是否为数字 |
| isxdigit | iswxdigit | 是否为16进制数字 |
| iscntrl | iswcntrl | 是否为控制字符 |
| isgraph | iswgraph | 是否为图形字符(例如,空格、控制字符都不是) |
| isspace | iswspace | 是否为空格字符(包括制表符、回车符、换行符等) |
| isblank | iswblank | 是否为空白字符(C99/C++11新增)(包括水平制表符) |
| isprint | iswprint | 是否为可打印字符 |
| ispunct | iswpunct | 是否为标点 |
| tolower | towlower | 转换为小写 |
| toupper | towupper | 转换为大写 |
在表格当中:
转换函数的用法为
char a='a';
a=toupper(a);
输出字符a即为A
判断类型函数一般用在if语句中
若判断为真则返回1,判断为假则返回0
即if内语句是否执行,从而完成进一步处理
字符数组的初始化与字符串的输入与输出
在一维数组与二维数组中的字符数组章节之中已经有了详细的解释
字符串函数
在函数的相关知识中的字符串函数已经有了基本的解释
当然也有要补充的地方
strncpy(字符串1,字符串2,n);
复制字符串2最多n个字符到字符串1中
strncmp(字符串1,字符串2,n);
将字符串1前n个字符与字符串2比较
strncat(字符串1,字符串2,n);
把字符串2的最多n个字符插入到字符串1的有效字符后面
strrev(字符串);
将字符串进行倒叙处理
strchr(字符串,所要查找的元素)
若查找到则输出该元素所在位置,若未查找则返回0值
stdio.h中的字符串函数
-
sprintf(字符数组名,格式字符串,输出项列表);
sprintf(a,"The price is %d",d);//仅仅将内容保存在字符数组a里而不是输出在屏幕
-
sscanf(字符数组名,格式字符串,输出项列表);
char a[100]={"45612319890308"};
int year,month,day;
sscanf(a,"%*6d%4d%2d%2d",&year,&month,&day);
printf("%4d-%02d-%02d",year,month,day);
sscanf用于读入从已存储的字符串之中抽取数据进行储存到变量之中