鱼C论坛

 找回密码
 立即注册
查看: 1049|回复: 1

[已解决]报错

[复制链接]
发表于 2023-10-24 11:29:15 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include<stdio.h>
#include<math.h>

char *
find_char( char const *source, char const *chars)
{
    char *temp = source;
    if (source == NULL || chars == NULL)
    {
        return NULL;
    }
    else if (*source == '\0'|| *chars  == '\0')
    {
        return NULL;
    }
    else
    {
        for (; *chars != '\0'; chars++)/*遍历chs数组*/
        {
            source = temp;
            for (; *source != '\0'; source++)
            {
                if(*source == *chars)
                    return source;


        }
        return NULL;

    }
}


int
main(void)
{
    char sour[7] = "ABCDEF";
    char chs[7] = "XRCQEF";
    char *result = find_char(sour, chs);
    printf("%c",*result);
    return 0;
}
代码为什么报错
最佳答案
2023-10-24 11:29:27
这段代码报错的原因是在调用 find_char 函数时,传入的 chars 参数是一个字符串字面量,而在函数内部的 for 循环中,尝试修改了 chars 指针的值,导致编译器报错。

在C语言中,字符串字面量是常量,其值不能被修改。而在这段代码中, find_char 函数尝试通过 chars++ 来修改 chars 指针的值,这是不允许的。因此,编译器报错。

要解决这个问题,可以将 chars 参数声明为 const char * 类型,以明确表示该参数是指向常量的指针,不可修改。修改后的代码如下:
char *
find_char(char const *source, char const *chars)
{
    char *temp = source;
    if (source == NULL || chars == NULL)
    {
        return NULL;
    }
    else if (*source == '\0' || *chars == '\0')
    {
        return NULL;
    }
    else
    {
        for (; *chars != '\0'; chars++) /*遍历chs数组*/
        {
            source = temp;
            for (; *source != '\0'; source++)
            {
                if (*source == *chars)
                    return source;
            }
        }
        return NULL;
    }
}

这样修改后,代码将不再报错,并且能够正常运行。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-10-24 11:29:27 | 显示全部楼层    本楼为最佳答案   
这段代码报错的原因是在调用 find_char 函数时,传入的 chars 参数是一个字符串字面量,而在函数内部的 for 循环中,尝试修改了 chars 指针的值,导致编译器报错。

在C语言中,字符串字面量是常量,其值不能被修改。而在这段代码中, find_char 函数尝试通过 chars++ 来修改 chars 指针的值,这是不允许的。因此,编译器报错。

要解决这个问题,可以将 chars 参数声明为 const char * 类型,以明确表示该参数是指向常量的指针,不可修改。修改后的代码如下:
char *
find_char(char const *source, char const *chars)
{
    char *temp = source;
    if (source == NULL || chars == NULL)
    {
        return NULL;
    }
    else if (*source == '\0' || *chars == '\0')
    {
        return NULL;
    }
    else
    {
        for (; *chars != '\0'; chars++) /*遍历chs数组*/
        {
            source = temp;
            for (; *source != '\0'; source++)
            {
                if (*source == *chars)
                    return source;
            }
        }
        return NULL;
    }
}

这样修改后,代码将不再报错,并且能够正常运行。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-5 19:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表