Chinaunix首页 | 论坛 | 博客
  • 博客访问: 409016
  • 博文数量: 78
  • 博客积分: 3642
  • 博客等级: 中校
  • 技术积分: 695
  • 用 户 组: 普通用户
  • 注册时间: 2006-10-23 15:33
文章分类

全部博文(78)

文章存档

2007年(53)

2006年(25)

分类: C/C++

2006-10-24 09:43:41


//从字符串末尾向首部进行比较

int strendcmp(const char* a, const char* b)
{
    int alen = strlen(a);
    int blen = strlen(b);

    int maxlen = alen < blen ? alen : blen;

    char* apos = (char*)a + alen - 1;
    char* bpos = (char*)b + blen - 1;

    unsigned char achar;
    unsigned char bchar;


    while(maxlen > 0)
    {
        achar = *apos ;
        bchar = *bpos ;
        if (achar > bchar)
        {
            return 1;
        }
        if (achar < bchar)
        {
            return -1;
        }
        maxlen --;
        apos --;
        bpos --;
   }

   if (alen > blen)
   {
        return 1;
   }
   if (alen < blen)
   {
        return -1;
   }
   return 0; // both equal

}

//安全的strcat函数

//max_len为dst的数组长度。

char * strcat_s(char * dst, char * src,int max_len)
{
  char * cp = dst;

  while( *cp ) ++cp; /* Find end of dst */

  while( (int)(cp - dst) < max_len )
  {
    if( (*cp++ = *src++) == 0 ) /* Copy src to end of dst */
        break;
  }

  dst[max_len -1] = 0;

  return dst;
}

阅读(1218) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~