如何从C字符串中删除第一个字符?

时间:2010-11-28 06:58:46

标签: c string cstring

任何人都可以帮助我吗?我需要从C中的char *中删除第一个字符。

例如,char * contents包含'\n'个字符作为数组中的第一个字符。我需要检测并消除这个字符,在它被“消毒”后修改原始变量。

任何人都可以帮我解决这些问题吗?我对C完全不熟悉,似乎无法弄明白。

7 个答案:

答案 0 :(得分:52)

if (contents[0] == '\n') 
    memmove(contents, contents+1, strlen(contents));

或者,如果指针可以修改:

if (contents[0] == '\n') contents++;

答案 1 :(得分:21)

char* contents_chopped = contents + 1;

这将导致contents_chopped指向相同的字符串,除了第一个字符将是\ n

之后的下一个字符串

此外,这种方法更快。

答案 2 :(得分:13)

如果你有malloc任何内存或你的程序崩溃,不要只是递增指针。 free需要原始指针。你可以复制指针,创建一大块内存并记忆它,以ptr + 1或任何其他方式访问它,但那些只是增加指针的人会给你危险的建议。您可以运行此示例程序,看看当“只是递增指针”时会发生什么。

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
int main(void)
{
    char *str = (char *)malloc(10);
    strcpy(str, "1234567890");
    printf("%s\n", str);
    str++;
    printf("%s\n", str);
    free(str);
}

提示:结果如下:

[mfisch@toaster ~]$ ./foo
1234567890
234567890
*** glibc detected *** ./foo: free(): invalid pointer: 0x08c65009 ***
======= Backtrace: =========
/lib/tls/i686/cmov/libc.so.6(+0x6b591)[0x724591]
/lib/tls/i686/cmov/libc.so.6(+0x6cde8)[0x725de8]
/lib/tls/i686/cmov/libc.so.6(cfree+0x6d)[0x728ecd]
./foo[0x80484e3]
/lib/tls/i686/cmov/libc.so.6(__libc_start_main+0xe6)[0x6cfbd6]
./foo[0x80483f1]
======= Memory map: ========
001c9000-001e4000 r-xp 00000000 08:01 2883609    /lib/ld-2.11.1.so
001e4000-001e5000 r--p 0001a000 08:01 2883609    /lib/ld-2.11.1.so
001e5000-001e6000 rw-p 0001b000 08:01 2883609    /lib/ld-2.11.1.so
006b9000-0080c000 r-xp 00000000 08:01 3015690    /lib/tls/i686/cmov/libc-2.11.1.so
0080c000-0080d000 ---p 00153000 08:01 3015690    /lib/tls/i686/cmov/libc-2.11.1.so
0080d000-0080f000 r--p 00153000 08:01 3015690    /lib/tls/i686/cmov/libc-2.11.1.so
0080f000-00810000 rw-p 00155000 08:01 3015690    /lib/tls/i686/cmov/libc-2.11.1.so
00810000-00813000 rw-p 00000000 00:00 0
00e4d000-00e4e000 r-xp 00000000 00:00 0          [vdso]
00fe0000-00ffd000 r-xp 00000000 08:01 2883667    /lib/libgcc_s.so.1
00ffd000-00ffe000 r--p 0001c000 08:01 2883667    /lib/libgcc_s.so.1
00ffe000-00fff000 rw-p 0001d000 08:01 2883667    /lib/libgcc_s.so.1
08048000-08049000 r-xp 00000000 08:01 9700477    /home/mfisch/foo
08049000-0804a000 r--p 00000000 08:01 9700477    /home/mfisch/foo
0804a000-0804b000 rw-p 00001000 08:01 9700477    /home/mfisch/foo
08c65000-08c86000 rw-p 00000000 00:00 0          [heap]
b7600000-b7621000 rw-p 00000000 00:00 0
b7621000-b7700000 ---p 00000000 00:00 0
b776f000-b7770000 rw-p 00000000 00:00 0
b7780000-b7783000 rw-p 00000000 00:00 0
bfc22000-bfc37000 rw-p 00000000 00:00 0          [stack]
Aborted

答案 3 :(得分:3)

听起来好像你的印象是char *“包含”字符。它不是。它只是 a 字节。字符串的其余部分暗示由内存中的后续字节组成,直到下一个空字节。 (您还应该知道,虽然'char'数据类型是一个字节,但根据定义,它实际上不是一个字符 - 请注意Unicode - 而且字节也不一定是八位字节。)

char *也不是数组,尽管可能存在一个字符数组,使得指针指向该数组的开头。

答案 4 :(得分:1)

getValue()

答案 5 :(得分:-1)

这是我的代码

char  * bastakiniSil(char *contents){
char *p = malloc( sizeof(*p) * strlen(contents) );
int i;
for(i=0; i<strlen(contents); i++)
{
    p[i]=contents[i+1];
}

return p;

}

答案 6 :(得分:-2)

这是我的代码。
就这么简单

#include <stdio.h>
#include<stdlib.h>
int main()
{
    char *str="hello";
    printf("%s",&str[1]);
    return 0;
}