字符串操作函数

  1. char * __cdecl strcat (
  2. char * dst,
  3. const char * src
  4. )
  5. {
  6. char * cp = dst;
  7. while( *cp )
  8. cp++;                   /* find end of dst */
  9. while( *cp++ = *src++ ) ;       /* Copy src to end of dst */
  10. return( dst );                  /* return dst */
  11. }
  12. wchar_t * __cdecl wcscat (
  13. wchar_t * dst,
  14. const wchar_t * src
  15. )
  16. {
  17. wchar_t * cp = dst;
  18. while( *cp )
  19. cp++;                   /* find end of dst */
  20. while( *cp++ = *src++ ) ;       /* Copy src to end of dst */
  21. return( dst );                  /* return dst */
  22. }
  23. char * __cdecl strcpy(char * dst, const char * src)
  24. {
  25. char * cp = dst;
  26. while( *cp++ = *src++ )
  27. ;               /* Copy src over dst */
  28. return( dst );
  29. }
  30. wchar_t * __cdecl wcscpy(wchar_t * dst, const wchar_t * src)
  31. {
  32. wchar_t * cp = dst;
  33. while( *cp++ = *src++ )
  34. ;               /* Copy src over dst */
  35. return( dst );
  36. }
  37. int __cdecl strcmp (
  38. const char * src,
  39. const char * dst
  40. )
  41. {
  42. int ret = 0 ;
  43. while( ! (ret = *(unsigned char *)src – *(unsigned char *)dst) && *dst)
  44. ++src, ++dst;
  45. if ( ret < 0 )
  46. ret = -1 ;
  47. else if ( ret > 0 )
  48. ret = 1 ;
  49. return( ret );
  50. }
  51. int __cdecl wcscmp (
  52. const wchar_t * src,
  53. const wchar_t * dst
  54. )
  55. {
  56. int ret = 0 ;
  57. while( ! (ret = (int)(*src – *dst)) && *dst)
  58. ++src, ++dst;
  59. if ( ret < 0 )
  60. ret = -1 ;
  61. else if ( ret > 0 )
  62. ret = 1 ;
  63. return( ret );
  64. }
  65. int __cdecl strncmp (
            const char * first,
            const char * last,
            size_t count
            )
    {
            if (!count)
                    return(0);
  66.         while (--count && *first && *first == *last)
            {
                    first++;
                    last++;
            }
  67.         return( *(unsigned char *)first - *(unsigned char *)last );
    }
  68. size_t __cdecl strlen (
  69. const char * str
  70. )
  71. {
  72. const char *eos = str;
  73. while( *eos++ ) ;
  74. return( (int)(eos – str – 1) );
  75. }
  76. size_t __cdecl wcslen (
  77. const wchar_t * wcs
  78. )
  79. {
  80. const wchar_t *eos = wcs;
  81. while( *eos++ ) ;
  82. return( (size_t)(eos – wcs – 1) );
  83. }
  84. char * __cdecl strncat (
            char * front,
            const char * back,
            size_t count
            )
    {
            char *start = front;
  85.         while (*front++)
                    ;
            front--;
  86.         while (count--)
                    if (!(*front++ = *back++))
                            return(start);
  87.         *front = '/0';
            return(start);
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值