C语言字符串操做函数整理

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int main()
{
    char *str1="hello world!";
    char *str2="HELLO WORLD!";
    int len=strlen(str1);//求的字符串长度,不包括'\0'在内
    printf("len=%d\n",len);

    int cmp=strcmp(str1,str2);
    printf("cmp=%d\n",cmp);
    //str1>str2,返回大于零的值,str1<str2返回小于零的值,等于返回0。比较方式是逐个字符比较
    //int strcmp(char *str1,char * str2,int n),只是能够控制个数,别的和strcmp()同样

    char str3[100]="hello world!";
    char str4[100]="HELLO WORLD!";
    strcat(str3,str4);
    printf("str3=%s\n",str3);
    //函数将字符串str4 链接到str3的末端,即抹掉str3结尾的'\0',可是str4结尾的'\0'保留并返回指针str3。
    //str4应该为const。str3的空间要足以容纳str3和str4,否则会发生溢出错误,此函数不安全

    char str5[100]="hello world!";
    char str6[100]="HELLO WORLD!";
    strncat(str5,str6,5);
    printf("str3=%s\n",str5);
    //这个函数和strcat()同样,只是相对更安全,能够显式的控制连接字符个数。
    //会抹掉str5的'\0',完了会自动添加'\0'

    char str7[100]="hello world!";
    char str8[100]="HELLO WORLD!";
    strcpy(str7,str8);
    printf("str7=%s\n",str7);
    //复制str8的内容到str7中,包括'\0',返回str7的指针,即所有抹掉str7的内容,换成str的
    //前提是str7的空间要足够大能够容纳str8的内容以及'\0',因此此函数是相对不安全的

    char str9[100]="hello world!";
    char str10[100]="HELLO WORLDDDD!";
    strncpy(str9,str10,14);
    len=strlen(str9);
    printf("str9=%s\n",str9);
    printf("str9 len=%d\n",len);
    /*
        译:拷贝 source 中的前 num 个字符到 destination 中去。若是在拷贝 num 个字符中遇
        到’\0’,则在其后而补’\0’; 若是 source 的长度大于 num,在拷贝完 num 个字符后,并不
        会在 destination 的后面追加’\0’。所在这种状况下,destination 不以’\0’结尾,读它可能
        会越界。
        一般做法是,依据 dest 的大小,设为 N,而后去读 N-1 个字符。而后将 dest[N-1]=
        ‘\0’;
    */
    //老师的文档如上所述,可是本身测试几回都没有出错,而且用strlen()统计也是正确的
    //使用此函数前提也是目标字符串的空间要足够,也只是相对的安全

    int a=192,b=168,c=100,d=111;
    char str11[18];
    sprintf(str11,"%d.%d.%d.%d",a,b,c,d);
    len=strlen(str11);
    printf("str11=%s\n",str11);
    printf("str11 len=%d\n",len);
    //函数功能:把格式化的数据写入某个字符串缓冲区。前提是缓冲区要存的下

    char str12[100]="   123abc";
    int data=atoi(str12);
    printf("str12 to data=%d\n",data);
    /*
     * 函数功能:将字符串转换成整型数;atoi()会扫描参数 nptr 字符串,跳过前面的空格字
     * 符,直到赶上数字或正负号才开始作转换,而再遇到非数字或字符串时('\0')才结束
     * 转化,并将结果返回(返回转换后的整型数),如果首个就是字符,那就返回0
     * 在stdlib.h中
    */

    data=123;
    char str13[100];
    itoa(data,str13,10);
    printf("base=10,str13=%s\n",str13);
    itoa(data,str13,2);
    printf("base=2,str13=%s\n",str13);
    /*
     *根据指定的进制(base),将整型数据转化为以’\0’结尾的字符串,保存到 str 指向的字符数组中。
     * stdlib.h中
    */

    char str15[100]="hello world!";
    char *p=strchr(str15,'l');
    printf("l in str15 first=%s\n",p);
    //函数功能:返回字符串 str 中首次出现字符 c 的位置指针,返不到返回 NULL。

    char str16[100]="ll";
    p=strstr(str15,str16);
    printf("str16 in str15 first=%s\n",p);
    //函数功能:strstr() 函数搜索字符串 str2 在字符串 str1 中是否出现。找到所搜索的字符
    //串,则该函数返回第一次匹配的字符串的地址;若是未找到所搜索的字符串,则返回NULL

    char str17[100]="aaa@bbb@ccc@ddd";
    char *str18=strtok(str17,"@");
    printf("str18=%s\n",str18);
    int i=0;
    for(i=0;i<3;i++){
        str18=strtok(NULL,"@");
        printf("str18=%s\n",str18);
    }
    /*
     * 功能:分解字符串为一组字符串。s 为要分解的字符串,delim 为分隔符字符串。
        说明:首次调用时,s 指向要分解的字符串,以后再次调用要把 s 设成 NULL。
        strtok 在 s 中查找包含在 delim 中的字符并用 NULL('\0')来替换, 直到找遍整个字符串。
        返回值:从 s 开头开始的一个个被分割的串。当没有被分割的串时则返回 NULL。
        全部 delim 中包含的字符都会被滤掉,并将被滤掉的地方设为一处分割的节点。
    */

    char str19[20]={0};
    //memset(str19,'y',sizeof(str19));
    memset(str19,'y',5);
    printf("memset str19=%s\n",str19);
    //功能: 函数拷贝ch 到buffer 从头开始的count 个字符里, 并返回buffer指针。
    //memset() 能够应用在将一段内存初始化为某个值。
    //例如:memset( the_array, '\0', sizeof(the_array) );
    //这是将一个数组的因此份量设置成零的很便捷的方法。

    char str20[100]="hello world!";
    char str21[100]="HELLO WORLD!";
    memcpy(str20,str21,5);
    printf("memcpy str21 to str20=%s\n",str20);
    //定义:void *memcpy( void *to, const void *from, size_t count );
    //功能:函数从from中复制count 个字符到to中,并返回to指针。若是to 和 from 重叠,函数行为不肯定。
    //应用于字符串做用相似于strncpy()

    char str22[100]="hello world!";
    char str23[100]="HELLO WORLD!";
    memmove(str22,str23,5);
    printf("memmove str23 to str22=%s\n",str22);
    //功能: 与mencpy相同,不一样的是当to 和 from 重叠,函数正常仍能工做。

    return 0;
}
相关文章
相关标签/搜索