这个题目本身其实没有什么难度,但是重在考察我们的细心程度,要考虑全面,尽可能提高程序鲁棒性。
首先要考虑到所输入的字符串是否是空字符串,空指针,输入的字符串是否有效,以及是否包含非法字符,如果正确的话则在考虑字符串的正负以及转换后的整数是否溢出。
<span style="font-size:18px;">//将一个字符串转换为整数 #include<stdio.h> #include<string.h> int main() { char *s="345"; int number=0; //printf("%c\n",s[1]); if(s==" ") { printf("空字符串\n"); } else if(s==NULL) { printf("空指针\n"); } else if((strcmp(s,"+")==0)||(strcmp(s,"-")==0)) { printf("输入字符串无效\n"); } else { char *p=s; int isfirst=1; //是否为第一个字符 int hasminus =0; //标记第一个符号是正负号 while(*p!='\0') { if(isfirst&&(*p)=='-') //表示第一个字符是负号 { hasminus=1; p++; continue; } else if(isfirst&&(*p)=='+') { p++; continue; } if((*p)>='0'&&(*p)<='9') //为数字字符 { number=number*10+(*p)-'0'; p++; } else { printf("非法字符\n"); break; } } if((!hasminus&&number>0x7FFFFFFF)||(hasminus&&number<(signed int)0x80000000)) { printf("字符串溢出\n"); } else if(hasminus) { number=(-1)*number; printf("%d\n",number); } else { printf("%d\n",number); } } return 0; }</span>
通过这个程序,也让我了解到char *s和char s[]的区别:
char *s1 的s1,指针是指向一块内存区域,它指向的内存区域的大小可以随时改变,而且当指针指向常量字符串时,它的内容是不可以被修改的,否则在运行时会报错。
char s2[]的s2 是数组对应着一块内存区域,其地址和容量在生命期里不会改变,只有数组的内容可以改变
char *s1 = "hello";
char s2[] = "hello";
s2=s1; //编译ERROR
s1=s2; //OK
分析:s2其地址和容量在生命期里不能改变,所以出错
s1[0]='a'; //×运行ERROR( 这一句好像在一些的编译器不会出错,原因待查)
s2[0]='a'; //OK
分析:运行时会报错,原因在于企图改变s1的内容,由于s1指向的是常量字符串,其内容是不可修改的,因此在运行时不会通过。而s2指向的是变量区字符串,可以修改。
下面是一些char *s1 和 char s2[]相同的地方(同样编译器对char[]做了隐式变化):
1)作为形参完全相同
如:
void function(char *s1);
void function(char s1[]);
2)只读取不修改的时候
如:
char *s1="hello";
char s2[]="hello";
printf("s1[1]=[%c]\n",s1[1]); //s1[1]=[e]
printf("s2[1]=[%c]\n",s2[1]); //s2[1]=[e]
printf("s1=[%s]\n",s1); //s1=[hello]
printf("s2=[%s]\n",s2); //s2=[hello]