[英]Implementation of ToLower function in C
我正在用C编写自己的ToLower(char * str)实现。但是我在函数中遇到了分段错误。 我写的功能是:
void ToLower(char *str)
{
while(*str != '\0')
{
if(*str >=65 && *str<=90)
{
// It fails in the below assignment
*str = *str + 32;
}
str++;
}
}
当您这样称呼它时,您几乎肯定会失败:
int main(void)
{
ToLower("HelloWorld");
return 0;
}
这是因为"HelloWorld"
是文字常量字符串,您无法更改其内容。
请尝试:
int main(void)
{
char str[] = "HelloWorld";
// Now str is your own local buffer, that you can modify.
// It is initialized with the text, but that text can be changed.
ToLower(str);
return 0;
}
通常,在对字符串进行操作的函数中接受长度参数是一种很好的形式。 这样,如果您传入的字符串不是以Null结尾的,则该函数不会循环到输入的末尾。
您可以使用调试器逐步完成函数调用,也可以在循环中添加一条print语句,以查看其迭代的次数。
尽管函数ToLower()
的名称表明您正在重写tolower()
的ANSI C版本(即,将一个字符从大写改为小写),但您的实现却建议您确实希望更改整个字符串。 也许名称StrToLower()
确实是您想要的? (即更改整个字符串)。 在这种情况下,将说明以下代码。 (如果您确实要重写tolower()
,那么它的确应该是一个不同的问题,其原型类似于C版本,并且每次调用仅更改一个char)
由于您的问题中的标记为“ c”,因此此答案假定您不想要String.ToLower()
的.NET版本(该版本确实会转换字符串)。 如果这是一个错误的假设,请无视我的怒吼。
此方法可与char *str="STRING";
,或使用常量字符串( "STRING"
)作为参数。
[扩展]包括ToLower的实现,以防OP真正想要的。
#include <stdio.h>
char * StrToLower(char *str) ;
int toLower(int chr);
int main(void)
{
char lowered[] = "UPPER to Lower";
sprintf(lowered, "%s",StrToLower(lowered));
printf("%s\n", lowered); //works with a variable buffer argument
lowered[0]=0;//clear the buffer
sprintf(lowered, "%s",StrToLower("UPPER to Lower"));
printf("%s\n", lowered); //also works with a literal string argument
getchar();//view results
return 0;
}
char * StrToLower(char *str)
{
char *pNew1 = str;
char *pNew2 = str;
if(str != NULL) //NULL ?
{
if(strlen(str) != 0) //"" ?
{
while(*pNew1)
{
*pNew2 = toLower(*pNew1);
++pNew2;
++pNew1;
}
*pNew2 = '\0';
return str;// return changed string
} // and prevent returning null to caller
}
return "";//Will never get here for non-null input argurment
}
int toLower(int chr)//touches only one character per call
{
return (chr >='A' && chr<='Z') ? (chr + 32) : (chr);
}
结果:(回答罗兰的评论)
对于安全变量,可以使用以下原型:
void ToLower(const char *str)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.