微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 硬件工程师文库 > 字符串常量的定义与引用

字符串常量的定义与引用

时间:08-14 来源:ZLG致远电子 点击:

周立功教授数年之心血之作《程序设计与数据结构》

第一章为程序设计基础,本文为1.8.2  字符串常量。

 

>>>>

1.8.2 字符串常量

 

字符的真正价值在于你可以将它们串在一起形成一个字符序列,即字符串常量,简称字符串。字符串常量就是使用一对双引号""""包围起来的,以空字符NUL(null character,NUL表示为'\0',ASCII码值为0x00)结尾的连续的字符串,其长度为字符串的长度加1。既然使用空字符结束字符串,那么printf()和strcpy()都将这一点作为默认的前置条件。

 

注意,NULL和NUL是不同的,NULL表示特殊的指针,通常定义为((void *)0),而NUL是一个char,定义为\0,两者不能混用。虽然字符常量是由单引号引起来的字符序列,通常由一个字符组成,但也可以包含多个字符,比如,转义字符,在C中它们的类型是int:

printf("%d\n", sizeof(char)); 

printf("%d\n", sizeof('a')); 

 

执行上述代码可以看到char的长度为1,而字符常量的长度为4。

 

只要在程序中使用字符串,就必须确定如何声明保存字符串的变量。如果将它声明为数组,则编译时就已经为各个字符保留了内存空间;如果将它声明为指针,则编译时完全没有为字符分配任何内存,仅在运行时分配空间。比如:

char       cStr[4] = "OK!";

char       *pcStr = "OK!"; 

 

两者的区别是,数组名cStr是常量,而指针名pcStr是变量。注意,如果在初始化指针之前就使用指针,有可能会导致运行出错,如果有以下定义:

char *pcStr; 

printf("%s", *pcStr); 

 

由于这里没有对pcStr初始化,因此其指向的内存是未知的,将会打印出奇怪的字符,于是pcStr自然也就成为了野指针。

 

>>> 1. 字符串的引用

 

由于"OK!"是一个字符串常量,因此是不可修改的。如果试图执行以下操作:

pcStr[2] = 'Z'; 

 

虽然编译期可以通过,但在运行时会出错。如果以下面这样的形式赋值:

char       cStr[4];

cStr = "OK!"; 

 

则是非法的,因为数组变量名cStr是一个不可修改的常量指针。

 

如果字符数组中没有保存'\0'',它仅仅是字符常量'O'、'K'、'!',不是字符串。即:

char       cStr[] = { 'O', 'K', '!'};

 

而"char cStr[] = "OK!";"只不过是"char cStr[]   = {'O', 'K', '!', '\0'};"的另一种写法,因为字符串是一种特殊的字符数组变量,所以其存储方式与数组变量一致。其中的cStr为数组变量名,表示此数组第0个元素的地址(即&cStr[0]),cStr+1表示数组第1个元素的地址(即&cStr[1]),cStr+2表示数组变量第2个元素的地址(即&cStr[2]),cStr+3表示数组变量第3个元素的地址(即&cStr[3]),其存储形式详见图1.13。

 

图1.13  "OK!"的存储形式

 

C语言中的字符串是以字符数组变量的形式处理的,具有数组的属性,所以不能赋值给整个字符数组变量,只能将字符逐个赋给字符数组变量。比如:

char       cStr[4];

cStr[0] = 'O';  cStr[1] = 'K';  cStr[2] = '!';  cStr[3] = '\0'; 

 

其存储的不是字符本身,而是以ASCII码存储的字符常量(即存值)。

 

惯用法

 

由于字符串常量以'\0'(ASCII码值为0x00)结尾,因此可以用cStr[i]作为for循环语句的"条件部分(布尔表达式)",检查cStr[i]是否为'\0'(cStr[i]是以*(cStr+i)形式表示的)。用于处理字符串中每一个字符的惯用法如下:

for(i = 0; cStr[i] != '\0'; i++)    … 

 

其等价于

for(i = 0; cStr[i]; i++) … 

 

同理"while(cStr[i] != '

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top