• C语言字符串函数大全


         

     C语言字符串函数大全

     

     

    函数名: stpcpy

    功 能: 拷贝一个字符串到另一个

     : char *stpcpy(char *destin, char *source);

    程序例:

     

    #include <stdio.h>

    #include <string.h>

     

    int main(void)

    {

       char string[10];

       char *str1 = "abcdefghi";

     

       stpcpy(string, str1);

       printf("%s\n", string);

       return 0;

    }

     

     

     

     

     

    函数名: strcat

     : 字符串拼接函数

     : char *strcat(char *destin, char *source);

    程序例:

     

    #include <string.h>

    #include <stdio.h>

     

    int main(void)

    {

       char destination[25];

       char *blank = " ", *c = "C++", *Borland = "Borland";

     

       strcpy(destination, Borland);

       strcat(destination, blank);

       strcat(destination, c);

     

       printf("%s\n", destination);

       return 0;

    }

     

     

     

     

    函数名: strchr

     : 在一个串中查找给定字符的第一个匹配之处\

     : char *strchr(char *str, char c);

    程序例:

     

    #include <string.h>

    #include <stdio.h>

     

    int main(void)

     {

        char string[15];

        char *ptr, c = 'r';

     

        strcpy(string, "This is a string");

        ptr = strchr(string, c);

        if (ptr)

           printf("The character %c is at position: %d\n", c, ptr-string);

        else

           printf("The character was not found\n");

        return 0;

     }

     

     

     

     

    函数名: strcmp

     : 串比较

     : int strcmp(char *str1, char *str2);

    Asicstr1>str2,返回值 > 0;两串相等返回0

    程序例:

     

    #include <string.h>

    #include <stdio.h>

     

    int main(void)

     {

        char *buf1 = "aaa", *buf2 = "bbb", *buf3 = "ccc";

        int ptr;

     

        ptr = strcmp(buf2, buf1);

        if (ptr > 0)

           printf("buffer 2 is greater than buffer 1\n");

        else

           printf("buffer 2 is less than buffer 1\n");

     

        ptr = strcmp(buf2, buf3);

        if (ptr > 0)

           printf("buffer 2 is greater than buffer 3\n");

        else

           printf("buffer 2 is less than buffer 3\n");

     

        return 0;

     }

     

     

     

     

    函数名: strncmpi

     : 将一个串中的一部分与另一个串比较, 不管大小写

     : int strncmpi(char *str1, char *str2, unsigned maxlen);

    程序例:

     

    #include <string.h>

    #include <stdio.h>

     

    int main(void)

    {

       char *buf1 = "BBB", *buf2 = "bbb";

       int ptr;

     

       ptr = strcmpi(buf2, buf1);

     

       if (ptr > 0)

          printf("buffer 2 is greater than buffer 1\n");

     

       if (ptr < 0)

          printf("buffer 2 is less than buffer 1\n");

     

       if (ptr == 0)

          printf("buffer 2 equals buffer 1\n");

     

       return 0;

    }

     

     

     

     

    函数名: strcpy

     : 串拷贝

     : char *strcpy(char *str1, char *str2);

    程序例:

     

    #include <stdio.h>

    #include <string.h>

     

    int main(void)

     {

        char string[10];

        char *str1 = "abcdefghi";

     

        strcpy(string, str1);

        printf("%s\n", string);

        return 0;

     }

     

     

     

     

    函数名: strcspn

     : 在串中查找第一个给定字符集内容的段

     : int strcspn(char *str1, char *str2);

    程序例:

     

    #include <stdio.h>

    #include <string.h>

    #include <alloc.h>

     

    int main(void)

     {

        char *string1 = "1234567890";

        char *string2 = "747DC8";

        int length;

     

        length = strcspn(string1, string2);

        printf("Character where strings intersect is at position %d\n", length);

     

        return 0;

     }

     

     

     

     

    函数名: strdup

     : 将串拷贝到新建的位置处

     : char *strdup(char *str);

    程序例:

     

    #include <stdio.h>

    #include <string.h>

    #include <alloc.h>

     

    int main(void)

     {

        char *dup_str, *string = "abcde";

     

        dup_str = strdup(string);

        printf("%s\n", dup_str);

        free(dup_str);

     

        return 0;

     }

     

     

     

     

    函数名: stricmp

     : 以大小写不敏感方式比较两个串

     : int stricmp(char *str1, char *str2);

    程序例:

     

    #include <string.h>

    #include <stdio.h>

     

    int main(void)

    {

       char *buf1 = "BBB", *buf2 = "bbb";

       int ptr;

     

       ptr = stricmp(buf2, buf1);

     

       if (ptr > 0)

          printf("buffer 2 is greater than buffer 1\n");

     

       if (ptr < 0)

          printf("buffer 2 is less than buffer 1\n");

     

       if (ptr == 0)

          printf("buffer 2 equals buffer 1\n");

     

       return 0;

    }

     

     

     

    函数名: strerror

     : 返回指向错误信息字符串的指针

     : char *strerror(int errnum);

    程序例:

     

    #include <stdio.h>

    #include <errno.h>

     

    int main(void)

    {

       char *buffer;

       buffer = strerror(errno);

       printf("Error: %s\n", buffer);

       return 0;

    }

     

     

     

     

    函数名: strcmpi

     : 将一个串与另一个比较, 不管大小写

     : int strcmpi(char *str1, char *str2);

    程序例:

     

    #include <string.h>

    #include <stdio.h>

     

    int main(void)

    {

       char *buf1 = "BBB", *buf2 = "bbb";

       int ptr;

     

       ptr = strcmpi(buf2, buf1);

     

       if (ptr > 0)

          printf("buffer 2 is greater than buffer 1\n");

     

       if (ptr < 0)

          printf("buffer 2 is less than buffer 1\n");

     

       if (ptr == 0)

          printf("buffer 2 equals buffer 1\n");

     

       return 0;

    }

     

     

     

     

    函数名: strncmp

     : 串比较

     : int strncmp(char *str1, char *str2, int maxlen);

    程序例:

     

    #include <string.h>

    #include <stdio.h>

     

    int main(void)

     

    {

       char *buf1 = "aaabbb", *buf2 = "bbbccc", *buf3 = "ccc";

       int ptr;

     

       ptr = strncmp(buf2,buf1,3);

       if (ptr > 0)

          printf("buffer 2 is greater than buffer 1\n");

       else

          printf("buffer 2 is less than buffer 1\n");

     

       ptr = strncmp(buf2,buf3,3);

       if (ptr > 0)

          printf("buffer 2 is greater than buffer 3\n");

       else

          printf("buffer 2 is less than buffer 3\n");

     

       return(0);

    }

     

     

     

    函数名: strncmpi

     : 把串中的一部分与另一串中的一部分比较, 不管大小写

     : int strncmpi(char *str1, char *str2);

    程序例:

     

    #include <string.h>

    #include <stdio.h>

     

    int main(void)

    {

       char *buf1 = "BBBccc", *buf2 = "bbbccc";

       int ptr;

     

       ptr = strncmpi(buf2,buf1,3);

     

      if (ptr > 0)

          printf("buffer 2 is greater than buffer 1\n");

     

       if (ptr < 0)

          printf("buffer 2 is less than buffer 1\n");

     

       if (ptr == 0)

          printf("buffer 2 equals buffer 1\n");

     

       return 0;

    }

     

     

     

    函数名: strncpy

     : 串拷贝

     : char *strncpy(char *destin, char *source, int maxlen);

    程序例:

     

    #include <stdio.h>

    #include <string.h>

     

    int main(void)

    {

       char string[10];

       char *str1 = "abcdefghi";

     

       strncpy(string, str1, 3);

       string[3] = '\0';

       printf("%s\n", string);

       return 0;

    }

     

     

     

    函数名: strnicmp

     : 不注重大小写地比较两个串

     : int strnicmp(char *str1, char *str2, unsigned maxlen);

    程序例:

     

    #include <string.h>

    #include <stdio.h>

     

    int main(void)

    {

       char *buf1 = "BBBccc", *buf2 = "bbbccc";

       int ptr;

     

       ptr = strnicmp(buf2, buf1, 3);

     

       if (ptr > 0)

          printf("buffer 2 is greater than buffer 1\n");

     

       if (ptr < 0)

          printf("buffer 2 is less than buffer 1\n");

     

       if (ptr == 0)

          printf("buffer 2 equals buffer 1\n");

     

       return 0;

    }

     

      

     

     

    函数名: strnset

     : 将一个串中的所有字符都设为指定字符

     : char *strnset(char *str, char ch, unsigned n);

    程序例:

     

    #include <stdio.h>

    #include <string.h>

     

    int main(void)

    {

       char *string = "abcdefghijklmnopqrstuvwxyz";

       char letter = 'x';

     

       printf("string before strnset: %s\n", string);

       strnset(string, letter, 13);

       printf("string after strnset: %s\n", string);

     

       return 0;

    }

     

     

     

    函数名: strpbrk

     : 在串中查找给定字符集中的字符

     : char *strpbrk(char *str1, char *str2);

    程序例:

     

    #include <stdio.h>

    #include <string.h>

     

    int main(void)

    {

       char *string1 = "abcdefghijklmnopqrstuvwxyz";

       char *string2 = "onm";

       char *ptr;

     

       ptr = strpbrk(string1, string2);

     

       if (ptr)

          printf("strpbrk found first character: %c\n", *ptr);

       else

          printf("strpbrk didn't find character in set\n");

     

       return 0;

    }

     

     

     

    调用格式:result = strpbrk(source-string, searching-string)
    用途:在源字符串(source-string)中找出最先含有搜索字符串(searching-string)中的任一字符的位置并返回,若找不到则返回空指针。
    注意:返回值是指向源字符串的指针,所以在使用返回结果的时候,请确保源字符串的有效性。
    举MSDN中的例子:
    数据:
    char string[100] = "The 3 men and 2 boys ate 5 pigs\n";
    char *result;
    调用:
    result = strpbrk( string, "0123456789" );//在string中找出最先出现0~9中某一个字符的位置
    printf( "1: %s\n", result++ );
    result = strpbrk( result, "0123456789" );
    printf( "2: %s\n", result++ );
    result = strpbrk( result, "0123456789" );
    printf( "3: %s\n", result );
    输出的结果是:
    1. 3 men and 2 boys ate 5 pigs//最先发现3

    2: 2 boys ate 5 pigs//最先发现2,注意这时开始源串是上一次的结果的下一位置,即跳过了数字'3',下同

    3: 5 pigs//最先发现5

     

     

     ------------------------

    函数名: strrchr

     : 在串中查找指定字符的最后一个出现

     : char *strrchr(char *str, char c);

    程序例:

     

    #include <string.h>

    #include <stdio.h>

     

    int main(void)

    {

       char string[15];

       char *ptr, c = 'r';

     

       strcpy(string, "This is a string");

       ptr = strrchr(string, c);

       if (ptr)

          printf("The character %c is at position: %d\n", c, ptr-string);

       else

          printf("The character was not found\n");

       return 0;

    }

     

     

     

     

    函数名: strrev

     : 串倒转

     : char *strrev(char *str);

    程序例:

     

    #include <string.h>

    #include <stdio.h>

     

    int main(void)

    {

       char *forward = "string";

     

       printf("Before strrev(): %s\n", forward);

       strrev(forward);

       printf("After strrev(): %s\n", forward);

       return 0;

    }

     

     

    函数名: strset

     : 将一个串中的所有字符都设为指定字符

     : char *strset(char *str, char c);

    程序例:

     

    #include <stdio.h>

    #include <string.h>

     

    int main(void)

    {

       char string[10] = "123456789";

       char symbol = 'c';

     

       printf("Before strset(): %s\n", string);

       strset(string, symbol);

       printf("After strset(): %s\n", string);

       return 0;

    }

     

     

     

     

    函数名: strspn

     : 在串中查找指定字符集的子集的第一次出现

     : int strspn(char *str1, char *str2);

    程序例:

     

    #include <stdio.h>

    #include <string.h>

    #include <alloc.h>

     

    int main(void)

    {

       char *string1 = "1234567890";

       char *string2 = "123DC8";

       int length;

     

       length = strspn(string1, string2);

       printf("Character where strings differ is at position %d\n", length);

       return 0;

    }

     

      

     

    函数名: strstr

     : 在串中查找指定字符串的第一次出现

     : char *strstr(char *str1, char *str2);

    程序例:

     

    #include <stdio.h>

    #include <string.h>

     

    int main(void)

    {

       char *str1 = "Borland International", *str2 = "nation", *ptr;

     

       ptr = strstr(str1, str2);

       printf("The substring is: %s\n", ptr);

       return 0;

    }

     

     

     

    函数名: strtod

     : 将字符串转换为double型值

     : double strtod(char *str, char **endptr);

    程序例:

     

    #include <stdio.h>

    #include <stdlib.h>

     

    int main(void)

    {

       char input[80], *endptr;

       double value;

     

       printf("Enter a floating point number:");

       gets(input);

       value = strtod(input, &endptr);

       printf("The string is %s the number is %lf\n", input, value);

       return 0;

    }

     

     

     

     

    函数名: strtok

     : 查找由在第二个串中指定的分界符分隔开的单词

     : char *strtok(char *str1, char *str2);

    程序例:

     

    #include <string.h>

    #include <stdio.h>

     

    int main(void)

    {

       char input[16] = "abc,d";

       char *p;

     

       /* strtok places a NULL terminator

       in front of the token, if found */

       p = strtok(input, ",");

       if (p)   printf("%s\n", p);

     

       /* A second call to strtok using a NULL

       as the first parameter returns a pointer

       to the character following the token */

       p = strtok(NULL, ",");

       if (p)   printf("%s\n", p);

       return 0;

    }

     

     

    用法:token = strtok(source-str,seperator-str)
    用途:在source-str中找出以seperator-str中的字符为分隔的字符串,即是源串中除去了含有分隔串中的所有字符后余下的一段段的字符串,每调用一次找到一串,找不到则返回空串。
    注意:返回值是指向源串的指针,所以同样要保证源串的有效性,此外,每次调用返回找到的子串的时候都会把源串中该子串的尾部字符(原来是搜索串中的某一字符)修改成'\0'字符。还有一个要注意的是,这个函数使用全局的静态缓冲区(函数自己的静态buffer),所以在某一个线程里不要同时调用这个函数来处理两个字符串,否则极易出现不正常的结果,正确的处理方法是先找出一个字符串中的所有子串,然后才转到处理另一个字符串。多线程之间则不会出现这种干扰。
    同样举MSDN中的例子:
    数据准备:
    char string[] = "A string\tof ,,tokens\nand some more tokens";
    char seps[] = " ,\t\n";
    char *token;
    调用示例:
    token = strtok( string, seps );
    while( token != NULL )
    {
    /* While there are tokens in "string" */
    printf( " %s\n", token );
    /* Get next token: */
    token = strtok( NULL, seps );
    /*注意到上面这个NULL,它表明的是从上次调用结果中strtok自有的缓冲区中继续取出余下的子串*/
    }
    显示结果:
    A //此时string[1]='\0',原先为空格
    string
    of
    tokens
    and
    some
    more
    tokens

     

     

     -----------------------

    函数名: strtol

     : 将串转换为长整数

     : long strtol(char *str, char **endptr, int base);

    程序例:

     

    #include <stdlib.h>

    #include <stdio.h>

     

    int main(void)

    {

       char *string = "87654321", *endptr;

       long lnumber;

     

       /* strtol converts string to long integer */

       lnumber = strtol(string, &endptr, 10);

       printf("string = %s long = %ld\n", string, lnumber);

     

       return 0;

    }

     

     

    函数名: strupr

     : 将串中的小写字母转换为大写字母

     : char *strupr(char *str);

    程序例:

     

    #include <stdio.h>

    #include <string.h>

     

    int main(void)

    {

       char *string = "abcdefghijklmnopqrstuvwxyz", *ptr;

     

       /* converts string to upper case characters */

       ptr = strupr(string);

       printf("%s\n", ptr);

       return 0;

    }

     

     

     

    函数名: swab

     : 交换字节

     : void swab (char *from, char *to, int nbytes);

    程序例:

     

    #include <stdlib.h>

    #include <stdio.h>

    #include <string.h>

     

    char source[15] = "rFna koBlrna d";

    char target[15];

     

    int main(void)

    {

       swab(source, target, strlen(source));

       printf("This is target: %s\n", target);

       return 0;

    }

     

     

    strncasecmp()

    compare part of two strings, ignoring case 

    Function


    SYNOPSIS

    #include <string.h>

    int strncasecmp(const char *s1, const char *s2, size_t n);


    DESCRIPTION

    The function strncasecmp() performs a case-insensitive string comparison for up to the first n characters of the strings pointed to by s1 and s2.


    PARAMETERS

    s1 

    Points to a string to compare.

    s2 

    Points to a string to compare.

    n 

    Is the maximum number of characters to compare.


    RETURN VALUES

    The function strncasecmp() returns a positive integer if, within the first n bytes of string s1 and string s2, disregarding case string s1 is lexically greater than string s2. It returns zero if, other than case, the first n bytes of the two strings are identical. Finally, strncasecmp() returns a negative integer if with the first n bytes, disregarding case string s1 is lexically less than string s2.


    CONFORMANCE

    UNIX 98.


    MULTITHREAD SAFETY LEVEL

    MT-Safe.


    PORTING ISSUES

    None.


    AVAILABILITY

    PTC MKS Toolkit for Professional Developers
    PTC MKS Toolkit for Enterprise Developers
    PTC MKS Toolkit for Enterprise Developers 64-Bit Edition

  • 相关阅读:
    POJ_1523 SPF (Tarjan 求割点)
    POJ 3177&& 3352
    POJ 基础数据结构
    Bellman Ford, SPFA 学习笔记(含有负权的单源最短路径)
    HDU_3062 Party (2SAT)
    POJ二分图最大匹配的简单题目
    POJ 2553 The Bottom of a Graph (Trajan 强连通分量 缩点)
    POJ_3678 Katu Puzzle (2SAT)
    HDU_3836 Equivalent Set (Trajan 强连通分量 缩点)
    POJ1904 King's Quest(Tarjan 求缩点)
  • 原文地址:https://www.cnblogs.com/kungfupanda/p/2456913.html
Copyright © 2020-2023  润新知