memcmp.c
上传用户:romrleung
上传日期:2022-05-23
资源大小:18897k
文件大小:2k
源码类别:

MySQL数据库

开发平台:

Visual C++

  1. /* Copyright (C) 2000 MySQL AB
  2.    This program is free software; you can redistribute it and/or modify
  3.    it under the terms of the GNU General Public License as published by
  4.    the Free Software Foundation; either version 2 of the License, or
  5.    (at your option) any later version.
  6.    This program is distributed in the hope that it will be useful,
  7.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  8.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  9.    GNU General Public License for more details.
  10.    You should have received a copy of the GNU General Public License
  11.    along with this program; if not, write to the Free Software
  12.    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
  13. /* memcmp(lhs, rhs, len)
  14.    compares the two memory areas lhs[0..len-1] ??  rhs[0..len-1].   It
  15.    returns  an integer less than, equal to, or greater than 0 according
  16.    as lhs[-] is lexicographically less than, equal to, or greater  than
  17.    rhs[-].  Note  that this is not at all the same as bcmp, which tells
  18.    you *where* the difference is but not what.
  19.    Note:  suppose we have int x, y;  then memcmp(&x, &y, sizeof x) need
  20.    not bear any relation to x-y.  This is because byte order is machine
  21.    dependent, and also, some machines have integer representations that
  22.    are shorter than a machine word and two equal  integers  might  have
  23.    different  values  in the spare bits.  On a ones complement machine,
  24.    -0 == 0, but the bit patterns are different.
  25. */
  26. #include "strings.h"
  27. #if !defined(HAVE_MEMCPY)
  28. int memcmp(lhs, rhs, len)
  29.      register char *lhs, *rhs;
  30.      register int len;
  31. {
  32.   while (--len >= 0)
  33.     if (*lhs++ != *rhs++) return (uchar) lhs[-1] - (uchar) rhs[-1];
  34.   return 0;
  35. }
  36. #endif