错误将字符串中的字符转换为大写

时间:2015-03-17 02:02:49

标签: c string exc-bad-access toupper

我试图将字符串的字符转换为大写字母

int main (void)
{
    int i = 0;
    int n = 0;
    static char *str[] = { "wow",
                           "RACEcar", 
                           "No devil lived on.",
                           "rotor" };

    for(i = 0; i < strlen(*str); i++)
    {
        if(str[i] != NULL)
        {
            n = function(str[i]);
        }
    }
    return 0;
}

int function(char* x)
{
   int i = 0;
   int j = strlen(x);
   char c;
   for(i = 0; i < j; i++)
   {
      c = toupper(x[i]);
      x[i] = c;
   }

   return 0;
}

我在exc bad access, code 2x[i] = c;时收到错误 我不确定为什么会出现此错误,是否需要创建另一个字符串并将c分配给新字符串? toupper返回字符的大写版本,但实际上并没有改变元素本身,所以我不确定将toupper返回值返回元素会有什么问题。

1 个答案:

答案 0 :(得分:2)

您的代码尝试修改字符串文字,这会导致未定义的行为。

字符串"No devil lived on." 不可修改。为了帮助编译器捕获错误,您应该将数组声明为:

static char const *str[] = { "wow", // etc.

由于历史原因,如果您忘记包含const,编译器必须让它通过而不会破坏编译。但它仍然是一个错误,并且一些编译器无论如何都会发出警告。

对于gcc,您可以使用标记-Wwrite-strings来禁用对历史案例的支持;这将导致为您的代码生成错误消息。