• strcpy, strcat,strcmp的介绍和模拟实现


    介绍:

    strcpy:拷贝字符串到目的字符串当中

    strcat:在目的字符串后面追加字符串

    strcmp:比较两个字符串

    我们先来大致了解一下这三种函数在C语=语言的库中是怎么实现的

    1.strcpy

     这里大致说的是,strcpy的功能是将source拷贝到destination中去,包括字符串的结束标志'\0',并在这里结束!

    它的返回值是一个char*的指针,指向的是目的字符串的第一个字符地址

    那么在知道以上的信息之后我们就可以着手来模拟实现一下strcpy了

    代码:

    1. #include
    2. #include
    3. char* my_strcpy(char* ptr1, const char* ptr2)
    4. {
    5. assert(ptr1 && ptr2);
    6. char* ret = ptr1;
    7. while (*ptr1++ = *ptr2++);
    8. return ret;
    9. }
    10. int main()
    11. {
    12. char arr[] = "abcdefg";
    13. char arr2[] = "holle";
    14. char* n = my_strcpy(arr, arr2);
    15. printf("%s\n", arr);
    16. printf("%c", *n);
    17. return 0;
    18. }

    另外值得一提的是,在使用strcpy函数的是时候,必须要保证目的数组足够大,能容纳下source字符串包括'\0',并且不能将source拷贝给source自己

    2.strcat

     大致内容说的是,从destination字符串的末尾'\0'处开始追加source字符串,并且source字符串的'\0'也会被追加到destination中

    返回值是追加之后字符串的首字符地址

    代码:

    1. char* my_strcat(char* ptr1, const char* ptr2)
    2. {
    3. assert(ptr1 && ptr2);
    4. char* ret = ptr1;
    5. while (*ptr1)
    6. {
    7. ptr1++;
    8. }
    9. while (*ptr1++ = *ptr2++)
    10. {}
    11. return ret;
    12. }
    13. int main()
    14. {
    15. char arr[30] = "abcdefg";
    16. char arr2[] = "holle";
    17. char* ret = my_strcat(arr, arr2);
    18. printf("%s", arr);
    19. return 0;
    20. }

    值得注意的是,destination的空间要足够大,能放得下source包括'\0',不然程序会崩掉 。

    当一个字符串自己给自己追加时是不行的,'\0'会被覆盖掉的

    3.strcmp

     strcmp是比较两个字符串的函数,这里比较并不是字符串的大小,而是第一个字符的大小(对应的ascii值),如果两个字符串的第一个字符相同那么就比较第二个,如果第二个也相同,那么就比较第三个,直到遇到字符'\0',如果有一方先遇到了'\0'而另一方没有遇到,那么先遇到‘\0'的就是较小的一方,因为'\0'的ascii值为0,最小!

    当str1大于str2时,返回一个大于0的数

    当strt1等于str2时,返回0

    当str1小于str2时,返回一个小于0的数

    1. int my_strcmp(const char* ptr1, const char* ptr2)
    2. {
    3. assert(ptr1 && ptr2);
    4. while (*ptr1 == *ptr2)
    5. {
    6. if (*ptr1 == '\0')
    7. return 0;
    8. ptr1++;
    9. ptr2++;
    10. }
    11. if (*ptr1 > *ptr2)
    12. return 1;
    13. else
    14. return -1;
    15. //return *ptr1 - *ptr2;
    16. }
    17. int main()
    18. {
    19. char arr[] = "abcdefg";
    20. char arr2[] = "abcdetg";
    21. int n = my_strcmp(arr, arr2);
    22. printf("%d", n);
    23. return 0;
    24. }

    大家要注意的,当str1不等于str2的时候,C库中并没有指定返回的是-1或1,而是大于0或小于0的数,不同编译器不同,大家在用VS的时候,返回的就是-1或1,但是在linux gcc的编译器下,就不是-1或1了,所以可以将上述的if else语句替换为下面的注释。

  • 相关阅读:
    C++报错:fatal error LNK1169: 找到一个或多个多重定义的符号
    Serverless computing
    DNS域名解析过程
    信号上的串联电阻是如何改善信号质量的
    全局光照RSM
    划分Vlan时需要注意的问题
    剑指offer 52 两个链表的第一个公共结点
    GP规范--STORE DATA
    Redis高级特性和应用(发布 订阅、Stream)
    上午面了个腾讯拿 38K 出来的,让我见识到了基础的天花板
  • 原文地址:https://blog.csdn.net/Javaxaiobai/article/details/126747005