当前位置:文档之家› c语言中字符变量字符串和字符数组应用 (1)

c语言中字符变量字符串和字符数组应用 (1)

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

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

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不必一定做如此处理?

相关主题
文本预览
相关文档 最新文档