[英]Truncating string causes segmentation fault
我想用C编写一个将输入字符串截断为32个字符的函数,但是下面的代码给我一个分段错误。 谁能解释为什么会这样?
void foo (char *value){
if (strlen(value)>32) {
printf("%c\n", value[31]); // This works
value[31] = '\0'; // This seg faults
}
}
如果您这样调用函数:
char str[] = "1234567890123456789012345678901234567890";
foo(str);
它将正常工作。 但是,如果您这样称呼它:
char *str = "1234567890123456789012345678901234567890";
foo(str);
这可能会导致段错误。
此处的区别在于,在前一种情况下, str
是一个char
数组,而在后一种情况下, str
是指向字符串常量的指针。 字符串常量通常位于内存的只读部分,因此尝试对其进行修改会导致核心转储。
您的程序应如下所示:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void foo(char **value) {
if (strlen(*value)>32) {
printf("%c\n", (*value)[32]);
(*value)[32] = '\0'; // You want the string length to be 32, so set 32th character to '\0' so 32 characters will be from 0 to 31
}
}
int main() {
char *str;
str = malloc(100); // Change 100 to max possible length of string user can enter
printf("Enter string : ");
scanf("%s", str);
foo(&str);
printf("Truncated string is %s\n", str);
free(str);
return 0;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.