C语言写了一个小程序,统计输入字符串长度的。函数调用不太会,请大侠帮忙调试一下
#include<stdio.h>#include<string.h>#include<stdlib.h>intstrlen(char*string);/*函数声明*/m...
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int strlen(char *string ); /*函数声明*/
main()
{
char astr;
astr = "abc";
strlen( &astr ); /*调用函数,完成字符串统计*/
}
int strlen(char *string ) /*这个函数验证过,没有问题。我用main函数调用就告警,输出也不对*/
{
int length = 0;
while( *string++ != '\0')
length +=1;
printf("length = %d\n",length);
return length;
} 展开
#include<string.h>
#include<stdlib.h>
int strlen(char *string ); /*函数声明*/
main()
{
char astr;
astr = "abc";
strlen( &astr ); /*调用函数,完成字符串统计*/
}
int strlen(char *string ) /*这个函数验证过,没有问题。我用main函数调用就告警,输出也不对*/
{
int length = 0;
while( *string++ != '\0')
length +=1;
printf("length = %d\n",length);
return length;
} 展开
2个回答
展开全部
#include<stdio.h>//头文件只需要这个
int strll(char *str ); //函数名字不能用strlen否则不会出结果的 strlen是内置函数
int main()
{
char *astr;//应该为指针
astr = "abc";
strll(astr); //指针直接过去 不必再加寻址符
return 0;
}
int strll(char *str )
{
int length = 0;
while( *str++ != '\0')
length +=1;
printf("length = %d\n",length);
return length;
}
帮你改好了 按照你的改的,主要有几个部分函数名字不能用strlen 否则会有重复声明的报警和错误。strlen为内置函数。 开始声明 astr应该为指针类型,要不不能赋值字符串
追问
我明白了!!
还有一个疑问: 字符串赋值,为什么是astr = "abc";呢?
astr不是指针吗?存放的不是地址吗?我以为应该这样赋值:
*astr = "abc"
追答
字符指针可以直接赋值的 表示直接指向他的地址。你的那句话的确写的麻烦。最简洁的
当然是 char *asrt="abc";
展开全部
strlen( &astr ); /*调用函数,完成字符串统计*/
上边这一句改为
strlen( astr ); /*调用函数,完成字符串统计*/
字符串名本身就表示地址
试试
上边这一句改为
strlen( astr ); /*调用函数,完成字符串统计*/
字符串名本身就表示地址
试试
追问
astr是一个char型变量, strlen函数需要的是一个指针,所以要用&操作符。
去掉这个操作符。程序运行报错。
追答
没有仔细看你的astr声明;
astr声明错误;
改为char*astr
因为若只是char,只是单个字符而非字符串
而你的astr=“abcd“明显是字符串
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询