当前位置: 首页 >> 程序设计 >> C语言中字符变量字符串和字符数组应用
 

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

作者:      来源:zz     发表时间:2006-08-14     浏览次数:      字号:    

字符变量(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;istr[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;istr[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不必一定做如此处理? 



原作者: 陶勇浩 
来 源: 成都

责任编辑 webmaster

 
 
 
 
 
评论更多>>
 
 
 
发表
 
姓名: QQ:
性别: MSN:
E-mail: 主页:
评分: 1 2 3 4 5
评论内容:
验证码:
  
  • 请遵守《互联网电子公告服务管理规定》及中华人民共和国其他各项有关法律法规。
  • 严禁发表危害国家安全、损害国家利益、破坏民族团结、破坏国家宗教政策、破坏社会稳定、侮辱、诽谤、教唆、淫秽等内容的评论 。
  • 用户需对自己在使用本站服务过程中的行为承担法律责任(直接或间接导致的)。
  • 本站管理员有权保留或删除评论内容。
  • 评论内容只代表网友个人观点,与本网站立场无关。
  •