这是我写的程序
#include <stdio.h>
int main(){
char buff[10];
if(buff == NULL){
printf("Hi..\t"); \\不能执行
}
getchar();
return 0;
}
这段程序为什么不能输出啊!
那我该怎么判断字符数组是否为空啊??
buff 取的是地址,所以不会 == NULL
应该改为:
if(strcmp(buff,"")==0)
{
printf("Hi..\t");
}
但由于buff没有清空,所以还是不会进入if
应该这样:
memset(buff,'\0',sizeof(buff));
if(strcmp(buff,"")==0)
{
printf("Hi..\t");
}
应该改为:
if(strcmp(buff,"")==0)
{
printf("Hi..\t");
}
但由于buff没有清空,所以还是不会进入if
应该这样:
memset(buff,'\0',sizeof(buff));
if(strcmp(buff,"")==0)
{
printf("Hi..\t");
}
温馨提示:答案为网友推荐,仅供参考
第1个回答 2010-12-16
buff是个指针,代表数组的首地址,当然这个地址是不空的啦,所以if的那个是不会成立的
应该改成if( buff[0] == NULL)
不过问题就是由于各个编译器对未初始化的数组中给的初始值是不一样的,所以你的buff没有初始化,就并不知道系统给的初始值是多少,在vc6中是为-52的;
所以可以改为if( (int) buff[0] == -52)
不过最好应该初始化,可以改为:
char buff[10]={0};
if( buff[0] == NULL)
应该改成if( buff[0] == NULL)
不过问题就是由于各个编译器对未初始化的数组中给的初始值是不一样的,所以你的buff没有初始化,就并不知道系统给的初始值是多少,在vc6中是为-52的;
所以可以改为if( (int) buff[0] == -52)
不过最好应该初始化,可以改为:
char buff[10]={0};
if( buff[0] == NULL)
第2个回答 2010-12-15
if(buff == NULL){
printf("Hi..\t"); \\不能执行
}
应改成
for(int i=0;i<9;i++)
if(buff[i] == NULL)
{
printf("Hi..\t");
}
printf("Hi..\t"); \\不能执行
}
应改成
for(int i=0;i<9;i++)
if(buff[i] == NULL)
{
printf("Hi..\t");
}
第3个回答 2010-12-15
for(i=0;buff[i]!='\0';i++)