字符变量(type`char`?字符串(string)和字符数组(type`char`arrary)是C语言中非常重要的结构成分,也是应用编程中常发生混淆?导致错误发生的成分?一?注意区别字符数组中的字符和字符串C语言中无字符串变量,但提供了字符数组character arrary)
用于存储字符串,例如:
char
str[]="Hello";
同时,字符数组亦用于存储字符或字符变量,例如:
/*存放字符例*/
char
Chars[]={`H``e`,`1``1`,`o`};
/*存放字符变量例*/
char
ch=getch();
char
CharVar[]=ch;
str和Chars的内容尽管由相同字母构成,但前者是字符串(str)后者为一列字符(Chars)?两者在内存中的结构不同,即字符串结尾有NULL
0(字符串终止符)?在应用编程实践中,常常需要从键盘获取字符,依次存入字符数组中,再以字符串输出函数输出到屏幕等,譬如,在中文环境?图形模式下中文字符的键盘输入和屏幕显示?如混淆字符数组中字符组与字符串的差别,则可能得到奇怪的结果?如例:
CharStr()
{
int i,CharNum=5;
unsigned char
str[80];
for(i=0;i<CharNum;i++)
str[i]=getch();/*给数组str赋字符值*/
printf("Output
string is:%s",str);/*输出错误*
/
}
此段程序码在编译器(BorlandC
3.1)可顺利通过,无错误或警告显示,但结果输出不正确,因为数组str内为字符组而非字符串,当用于字符串函数操作时,因未能遭遇字符串终止符(NULL),printf将str[4]以后的空字节也作为字符串的一部分处理,导致屏幕输出不正确?解决办法是在字符组末尾加NULL字符('\0'),转换此字符数组内的字符组为字符串,重写前述程序码为:
CharStr()
{
int i, CharNum=5;
unsigned char
str[80];
for(i=0;i<CharNum;i++)
str[i]=getch();/*给数组str赋字符值*/
str[5]=`\0';/*加NULL,转换为字符串*/
printf("Output
string
is:%s",str);}
现在结果输出显示正常?
二?为函数strcat等字符串处理函数的目的字符串分配内存空间Borland
C(Turbo C)和Microsoft
C的strca等函数是常用的字符串操作函数,切记在使用前先为其目的字符串分配合适的内存空间,否则将可能发生乎意料的错误?下面的程序码在编译器或许通过顺利,但可能产生错误的结果:
ConcatStr(char
*str)
{ char*
ptr;
char*ptr=strcat("hello",str);/*错误!*/
printf("New
string=%s",ptr);
return;}
问题源于没有为字符串指针ptr指向的字符串"Hello"分配内存空间?函数strcat(char
*dist,char
*src)返回*dist的地址,
因此,*dist必须指向一个适当大小的内存缓冲区(安全的大小应>=dist+stc+1)下面是正确的程序码:
ConcatStr(void)
{char
buffer[80]; /*静态分配一内存缓冲区给buffer*
/
strcpy(buffer,"Hello");
/*拷贝字符串"Hello"到b
uffer缓冲区*/
strcat(buffer,"World");
/*链接字符串"friends"到
buffer缓冲区*/
printf("New
string=%s",buffer);
return;}
三?正确应用字符变量类型char的singed和unsigned前缀假如说明一个字符变量类型为char,多数编译器会缺省地将其视
为signed?若此字符变量只用于存放字符,即使是ASCII序数在128-255的字符,亦不会有问题发生?但若将此变量用于与整型数比较,或作为一个数组的索引序号,则可能会发生问题:
IndxChar(void)
{int
i;
char ch,outch; /*缺省为signed*/
char
Indx[255];
for(i=0;i<255;i++)
Indx[i]=i;
ch=getchar();
if(ch>127
&&ch<255)/*与>127的整型数比较,结果非
true*/
outch=Indx[ch];
/*错误!作为数组的索引*/
outch=`\x40'; /*如果非ture,则给
outch赋@值*/
printf("output
character=%c",outch);
return;}
上述程序码将总是输出字符@(ASCII
64)?因为signed
char类型赋值范围是0-127,超出此范围的字符(128-255),计算机视其
为负数,所以if判断句的结果总是Fail?正确的做法是把字符变量ch说明为unsigned,重写上面的程序码:
IndxChar(void)
{
int i;
unsigned char ch; /*说明字符变量ch为unsigned*/
char
outch;
char
Indx[255];
for(i=0;i<255;i++)
Indx[i]=i;
ch=getchar();
if(ch>127&&ch<255)
/*OK!*/
outch=Indx[ch];
/*OK!*/
outch=`\x40';
printf("output
character%c",outch);
return;}
现在编译过程中不会再有警告或错误信息,输出结果亦正常?补充一点,只须将作为对象的字符变量ch说明为unsigned,对字
符变量outch不必一定做如此处理?




