019 C语言中字符变量字符串和字符数组应用

更新时间:2023-05-25 15:43:01 阅读量: 实用文档 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

C语言中字符变量字符串和字符数组应用


字符变量(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&
quot;到b
uffer缓冲区*/
strcat(buffer,"World"); /*链接字符串"friends"到
buffer缓冲区*/
printf("New string=%s",buffer);
retu

rn;}
三?正确应用字符变量类型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=`\x
40';
printf("output character%c",outch);
return;}
现在编译过程中不会再有警告或错误信息,输出结果亦正常?补充一点,只须将作为对象的字符变量ch说明为unsigned,对字
符变量outch不必一定做如此处理?

本文来源:https://www.bwwdw.com/article/c154.html

Top