69,373
社区成员
发帖
与我相关
我的任务
分享
/* Copyright (C) 1991, 1996, 1997, 2003 Free Software Foundation, Inc.
This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with the GNU C Library; if not, write to the Free
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
02111-1307 USA. */
#include <string.h>
#include <memcopy.h>
#undef strcmp
/* Compare S1 and S2, returning less than, equal to or
greater than zero if S1 is lexicographically less than,
equal to or greater than S2. */
int
strcmp (p1, p2)
const char *p1;
const char *p2;
{
register const unsigned char *s1 = (const unsigned char *) p1;
register const unsigned char *s2 = (const unsigned char *) p2;
unsigned reg_char c1, c2;
do
{
c1 = (unsigned char) *s1++;
c2 = (unsigned char) *s2++;
if (c1 == '\0')
return c1 - c2;
}
while (c1 == c2);
return c1 - c2;
}
libc_hidden_builtin_def (strcmp)
int cmpstr (char s1[],char s2[]) {
int i=0;
while(s1[i]!='\0'&&s2[i]!='\0') {
if(s1[i]>s2[i]) {
return 1;
}
if(s1[i]<s2[i]) {
return -1;
}
i++;
}
if(s1[i]=='\0'&&s2[i]=='\0') {
return 0;
}
}
int strcmp(char* str1, char* str2)
{
ASSERT( ( str1 != NULL ) && ( str2 != NULL ) );
if ( *str1 != *str2 )
return ( (*str1) - (*str2) );
else
{
if ( *str1 == '\0' && *str2 == '\0' )
return 0;
else
return strcmp( str1+1, str2+1 );
}
}
void strcpy(char* Dest, char* Src)
{
ASSERT((Dest != NULL) && (Src != NULL) );
while( *Src != '\0' && *Dest != '\0' )
{
*Dest++ = *Src++;
}
}
int strcmp(char *p1,char *p2)
{
if(!p1 || !p2)
{
printf("illeg pointer\n");
exit(0);
}
while(*(p1)!= '\0' && *(p2)!= '\0')
{
if(*p1!=*p2)
return ((*p1)-(*p2));
else
{
p1++;
p2++;
continue;
}
}
if(*p1== '\0' && *p2=='\0')
return 0;
else
return ((*p1)-(*p2));
}