C没有为字符串定义专门的变量类型,而是把它存储在char数组中。
字符串中的字符存放在相邻的存储单元,中每个字符占用一个单元;而数组由相邻存储单元组成,所以把字符串存储到数组中是很自然的。
数组的最后一个位置显示字符\0。这个字符就是空字符,C用它来标记字符串的结束。
空字符不是数字0;它是非打印字符,其ASCII码的值为0。C的字符串存储时通常以这个空字符结束。
该字符的存在意味着数组的单元数必须至少比要存储的字符数多 1。
无须亲自把空字符插入字符数组中,scanf();在读取输入时会自动完成这项任务。而#define定义的字符串常量,编译器负责插入空字符。
并且scanf()开始读取输入以后,会在遇到的 第一个空白字符空格blank,制表符tab或者换行符处停止读取,scanf()只会把一个单词而不是把整个语句作为字符串读入。
C使用其他读取输入函数gets();
字符串和字符
字符串常量“x”与字符常量“x”不同。其中一个区别是‘x’属于基本类型char,而“x”则属于派生类型char数组。第二个区别是“x”实际上由两个字符(‘x’和空字符‘\0’)组成。
根据sizeof运算符的报告,数组name有40个内存单元。不过只用了其中前6个单元来存放Morgan,这是strlen所报告的。
数组name中的第7个但愿存放空字符,它的存在告诉strlen在哪里停止计数。
常量和C预处理器
#define pi 3.1415
编译器会在每个出现它的地方替换它。
创建符号常量的 第二种方法
const int month = 12;
这时month是一个只读值。
还有第三种方法创建常量,那就是枚举类型(enum)
本文介绍了C语言如何处理字符串,包括存储方式、结束符及常用输入输出函数的特点,并对比了字符串常量与字符常量的区别。
3559

被折叠的 条评论
为什么被折叠?



