0

我正在尝试在 ansi C 中的字符串中编写简单的函数修剪空间。

我的 str_utis.h:

#include <string.h>

const char* trim_str(char *input_str); 

我的 str_utils.c:

const char* trim_str(char* input_str){
    char* str = NULL;
    int len = strlen(input_str);
    int i = 0;
    for (i = 0; i < len - 1; i++){
        if (input_str[i] == ' ')
            ;
        else
            str += input_str[i];
    }
    return str;
}

当我尝试执行它时,我得到了段错误:

int main(int argc, char** argv) {
    const char* a = trim_str("Hey this is string");
    printf("%s", a);
    return 0;
}

为什么错了?我怎样才能正确写?

谢谢你。

4

6 回答 6

4

您不能修改字符串文字。是UB。复制字符串并修改其内容。改变

char* str = NULL;
int len = strlen(input_str);

size_t len = strlen( input_str );
char *str = malloc( len + 1 );

然后继续复制非空白内容。

于 2012-05-23T10:09:12.650 回答
2

str 未分配,并且无论如何您都不能使用 += 附加到字符串。阅读 strncat。

于 2012-05-23T10:09:05.530 回答
1

通过这个。这将从输入字符串的两端删除空格和制表符。

const char* trim_str(char* input_str){
    char* str = NULL;
    int len = strlen(input_str);
    str = (char *)malloc(len+1);
    int i = 0;
    while(i < len && (input_str[i]==' ' || input_str[i]=='\t')){
        ++i;
    }
    int j = 0;
    while(i< len && input_str[i]!=' ' && input_str[i]!='\t'){
      str[j]= input_str[i];
      ++j;
      ++i;
    }
   str[j] = '\0';

   return str;
  }
于 2012-05-23T10:24:13.527 回答
1

首先,您需要获得不带空格的新字符串大小:如果不需要,您不想分配大字符串。

   const char* trim_str(char* input_str){
        char* str = NULL;
        int len = strlen(input_str);
        int i = 0;
        int newSize = 0; 
        for (i = 0; i < len - 1; i++){
            if (input_str[i] == ' ')
                ;
            else
                newSize++;
        }
        str = malloc( newSize+ 1 );
        str[newSize] = '\0'

        // put the code of the copy bytes here...

        return str;
    }
于 2012-05-23T10:25:22.813 回答
1
char *trimdupstr(char *str)
{
size_t len, src,dst;
char *new;

if (!str) return NULL;
len = strlen (str);
new = malloc(len+1);
if (!new) return NULL;

for(src=dst=0; new[dst] = str[src++];   ) {
        if (new[dst] != ' ') dst++;
        }
return new;
}

这个也删除了标签和 CR/LF:

char *trimdupstr(char *str)
{
size_t len, src,dst;
char *new;

if (!str) return NULL;
len = strlen (str);
new = malloc(len+1);

for (src=dst=0; str[src]; dst += len) {
        len = strspn(str+src, "\t \r\n" );
        src += len;
        len = strcspn(str+src, "\t \r\n" );
        memcpy (new+dst, str+src, len);
        src += len;
        }
new[dst] = 0;
return new;
}
于 2012-05-23T10:30:58.750 回答
1

这是一个相当安全的方法。

void rtrim(char instrng[]) {
assert (instrng != NULL);
if (strlen(instrng) == 0) {
    return;
}
while (instrng[strlen(instrng)-1] == '\n' || instrng[strlen(instrng)-1] == ' ' ) {
    instrng[strlen(instrng)-1] = '\0';
}
return; 
}
于 2012-05-24T03:09:24.810 回答