• strlen函数,strcat函数,strcpy函数,strncpy函数,strcmp函数


    strcpy函数

    1. char *strcpy(char *Dest , const char *Src)  
    2. {  
    3.     assert((Dest != NULL) && (Src != NULL));  
    4.     char *address = Dest;  
    5.     while((*Dest++ = *Src++) != '')  
    6.         NULL;  
    7.     return address;  
    8. }  


    strncpy函数

    利用标准库函数strncpy(),可以将一字符串的一部分拷贝到另一个字符串中。strncpy()函数有3个参数:第一个参数是目录字符串;第二个参数是源字符串;第三个参数是一个整数,代表要从源字符串拷贝到目标字符串中的字符数。

    1. char *strncpy(char *strDest , const char *strSrc , int n)  
    2. {  
    3.     assert((strDest != NULL) && (strSrc != NULL));  
    4.     char *address = strDest;  
    5.     while(n-- > 0)  
    6.         *strDest++ = *strSrc++;  
    7.     return address;  
    8. }  

    strcmp函数

    strcmp函数是C/C++中基本的函数,它对两个字符串进行比较,然后返回比较结果,函数形式如下:
        int strcmp(constchar*str1,constchar*str2);
    其中str1和str2可以是字符串常量或者字符串变量,返回值为整形。返回结果如
    下规定:
    ①str1小于str2,返回负值或者-1(VC返回-1);
    ②str1等于str2,返回0;
    ③str1大于str2,返回正值或者1(VC返回1);
    strcmp函数实际上是对字符的ASCII码进行比较,实现原理如下:首先比较两个串的第一个字符,若不相等,则停止比较并得出两个ASCII码大小比较的结
    果;如果相等就接着比较第二个字符然后第三个字符等等。无论两个字符串是什么样,strcmp函数最多比较到其中一个字符串遇到结束符'/0'为止,就能得出结果。

    1. int strcmp(const char* str1, const char* str2)  
    2. {  
    3.    assert((str1 != NULL) && (str2 != NULL);  
    4.    int ret = 0;  
    5.    while (!(ret = (unsigned char*)*str1 - (unsigned char*)*str2) && (*str2))  
    6.    {  
    7.       str1++;  
    8.       str2++;  
    9.    }  
    10.    if (ret > 0)  
    11.    {  
    12.         return 1;  
    13.    }  
    14.    else if (ret < 0)  
    15.    {  
    16.         return -1  
    17.    }  
    18.    return 0;  
    19. }  



    strlen函数

    1. int strlen(const char *str)  
    2. {  
    3.     assert(str != NULL);  
    4.     int len;  
    5.     while((*str++) != '')  
    6.     {  
    7.         len++;  
    8.     }  
    9.     return len;  
    10. }  

    strcat函数原型

    1. //将源字符串加const,表明其为输入参数  
    2. char *strcat(char *strDest, const char *strSrc)  
    3. {  
    4.   // 后文return address,故不能放在assert断言之后声明address  
    5.   char *address = strDest;  
    6.   assert((strDest != NULL) && (strSrc != NULL)); //对源地址和目的地址加非0断言  
    7.   while(*strDest)             //是while(*strDest!=’’)的简化形式  
    8.   {  
    9.     //若使用while(*strDest++),则会出错,因为循环结束后strDest还会执行一次++,  
    10.     //那么strDest将指向''的下一个位置。/所以要在循环体内++;因为要是*strDest最后指  
    11.     //向该字符串的结束标志’’。  
    12.     strDest++;  
    13.   }  
    14.    
    15.   while(*strDest++ = *strSrc++)  
    16.   {  
    17.     NULL;             //该循环条件内可以用++,  
    18.   }                   //此处可以加语句*strDest=’’;无必要  
    19.   return address;     //为了实现链式操作,将目的地址返回  
    20. }  


    memcpy函数:

    功能:从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中。

    void* memcpy(void *dest , const void* src , size_t count)    
    {    
        assert( (dest != NULL) && (src != NULL));     //安全检查    
        assert(count > 0);    
        char* psrc = (char *)src;    
        char* pdest = (char *)dest;    
        while(count--)    
        {    
            *pdest++ = *psrc++;    
        }    
        return dest;    
    }   

    编写一个strcat函数:

      1. #include <stdio.h>  
      2.   
      3. char* strcat(char *str1,char *str2)  
      4. {  
      5.     char* tempt = str1;  
      6.       
      7.     while(*str1!='')  
      8.     {  
      9.         str1++;  
      10.     }  
      11.       
      12.     while(*str2!='')  
      13.     {  
      14.         *str1 = *str2;  
      15.         str1++;  
      16.         str2++;  
      17.     }  
      18.       
      19.     *str1 = '';  
      20.     return tempt;  
      21. }  
      22.   
      23. int main()  
      24. {  
      25.     char a[20] = "hello";  
      26.     char b[20] = ",world!";  
      27.     printf("%s ",strcat(a,b));  
      28.     return 0;  
      29.  } 
  • 相关阅读:
    高效沟通
    Oracle播放多条 INSERT ALL
    oracle的同义词总结
    Brute force Attack
    爱因斯坦方程与小黑洞
    dom 编程(html和xml)
    dexposed框架Android在线热修复
    从微软小冰看微软运营手段的转型
    剑指offer_面试题_从上往下打印二叉树
    外面的wifi非常精彩,外面的wifi非常不安
  • 原文地址:https://www.cnblogs.com/heyonggang/p/3196922.html
Copyright © 2020-2023  润新知