string.h库函数的实现---strcmp

本文深入解析了字符串比较函数的实现原理,通过词典序规则对比字符大小,详细介绍了使用指针进行字符串比较的过程,以及如何判断字符串的大小关系。

作用:比较两个字符串的大小,按照词典序的原则对字符大小进行定义,依次比较对应的字符的大小。

实现机制:字符串传参可用指针接收,将两个指针分别指向两个字符串的起始地址,解引用比较第一个字符的大小,如果arr1>arr2则返回一个大于0的数,arr1<arr2返回一个小于0的数,arr1 = arr2时,将指针向后移动,比较下一个字符,直至一个字符串走至’\0’,则另一个字符串即为较大的字符串,如果两个字符串都走至’\0’,则说明两个字符串是相同的,一样大,则返回0。

函数实现

int my_strcmp(const char* dest, const char* str)
{
	assert(dest != NULL && str != NULL);
	while (*str != '\0')
	{
		if (*dest < *str)
		{
			return -1;
		}
		
		else if (*dest > *str)
		{
			return 1;
		}
		dest++;
		str++;
	}
	return 0;
}

参考代码

#include <stdio.h>
#include <assert.h>

int my_strcmp(const char* dest, const char* str)
{
	assert(dest != NULL && str != NULL);
	while (*str != '\0')
	{
		if (*dest < *str)
		{
			return -1;
		}
		
		else if (*dest > *str)
		{
			return 1;
		}
		dest++;
		str++;
	}
	return 0;
}

int main()
{
	char arr1[1024] = "hello ";
	char arr2[1024] = "hello world";

	if (my_strcmp(arr1, arr2) > 0)
	{
		printf("arr1 > arr2\n");
	}
	else if (my_strcmp(arr1, arr2) < 0)
	{
		printf("arr1 < arr2\n");
	}
	else
	{
		printf("arr1 = arr2");
	}

	return 0;
}

运行结果展示
在这里插入图片描述

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值