C语言常用库函数的使用及模拟实现详解例举

 更新时间:2022年04月13日 09:09:08   作者:小刘好好学习  
C语言库函数是把自定义函数放到库里,是别人把一些常用到的函数编完放到一个文件里,供程序员使用,下面让我们一起来详细了解它

经历了C语言基础篇的学习,让我们来简单了解几个C语言的库函数!

1.strlen

字符串已经 '\0' 作为结束标志,strlen函数返回的是在字符串中 '\0' 前面出现的字符个数(不包 含 '\0' )。

 函数的模拟实现

1.计数法

int my_strlen(dest)
{
int count=0;
    while(dest)//当dest等于'\0'时停止循环
{
    count++;
    dest++;
}
return count;
}

2.递归法

int my_strlen(char* dest)
{
    int count=0;
    if(*dest!='0')
    {
        dest++;
        count++;
        return my_strlen(dest,count)
    }
    else
    return count;
}

3.指针减指针

int my_strlen(char* dest)
{
    char* arr=dest;//定义一个新指针指向dest
    while(*arr)//直到arr指向'\0'
    {
    arr++;
    }
    return (arr)-(dest);//指针相减代表两个指针之间的元素个数
}

2.strcpy

char* strcpy ( char * destination , const char * source )

会将源字符串中的 '\0' 拷贝到目标空间。

目标空间必须足够大,并且可变以确保能存放源字符串。

 函数的模拟实现

char* my_strcpy(char* dest, const char* str)
{
	char* arr1 = dest;
	while ((*dest++ = *str++)!='\0')
	{
		;
	}
	return arr1;
}
int main()
{
	char arr1[] = "***************";
	char arr2[] = "hello word";
	my_strcpy(arr1, arr2);
	printf("%s", arr1);
	return 0;
}

3.strcmp

int strcmp ( const char * str1, const char * str2 );

第一个字符串大于第二个字符串,则返回大于0的数字

第一个字符串等于第二个字符串,则返回0

第一个字符串小于第二个字符串,则返回小于0的数字

函数的模拟实现

int my_strcmp(char* arr1,char* arr2)
{
	while(*arr1 == *arr2)
	{
		if (*arr1 == '\0' && *arr2 == '\0')
		{
			return 0;
		}
		else
		{
			arr1++; arr2++;
 
		}
	}if (*arr1 > *arr2)
	{
		return 1;
	}
	else if (*arr1 < *arr2)
	{
 
		return -1;
	}
}

4.strcat

char * strcat ( char * destination, const char * source );

函数的模拟实现

char* my_strcat(char* dest, char* str)
{
	char* ret = dest;
	while (*dest)
	{
		dest++;
	}
	while (*dest++=*str++)
	{
		;
	}
	return ret;
}
int main()
{
	char arr1[50] = "hello";
	char arr2[] = "word";
	char* count=my_strcat(arr1, arr2);
	printf("%s", count);
	return 0;
}

5.strstr

char * strstr ( const char *str1, const char * str2);

函数的模拟实现

char* my_strstr(char* dest, char* str)
{
	char* arr1 = str;
	char* cur = dest;
	while (*cur)
	{
		str = arr1;
		dest = cur;
		if (*dest != *str)
		{
			dest++;
			str++;
		}
		else if (*dest == *str)
		{
			while (*dest == *str)
			{
				dest++; str++;
 
			}if (*str == '\0')
			{
				return cur;
			}
		}
		cur++;
	}return NULL;
}
int main()
{
	char arr1[] = "abbbcdef";
	char arr2[] = "bbc";
	char* ret=my_strstr(arr1, arr2);
	if (NULL == ret)
	{
		printf("找不到子串\n");
	}
	else
	{
		printf("%s\n", ret);
	}
	return 0;
}

6.strtok

char * strtok ( char * str, const char * sep );

strtok函数的第一个参数不为 NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串中的位置。

strtok函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标记

int main()
{
	char buff[] = "www.aaabbbccc@qq.com";
	char buf[20] = { 0 };
	strcpy(buf, buff);
	char* sep=".@";
	char* str = NULL;
	for (str = strtok(buf, sep); str != NULL; str = strtok(NULL, sep))
			{//NULL是从保存好的位置开始往后找
				printf("%s\n", str);
			}
	return 0;
}

7.字符分类函数

iscntrl 任何控制字符
isspace空白字符:空格‘ ’,换页‘\f’,换行'\n',回车‘\r’,制表符'\t'或者垂直制表符'\v'
isdigit十进制数字 0~9
isxdigit十六进制数字,包括所有十进制数字,小写字母a~f,大写字母A~F
islower小写字母a~z
isupper大写字母A~Z
isalpha字母a~zA~Z
isalnum字母或者数字,a~z,A~Z,0~9
ispunct 标点符号,任何不属于数字或者字母的图形字符(可打印)
isgraph
任何图形字符
isprint任何可打印字符,包括图形字符和空白字符

8.memcpy&memmove

void * memcpy ( void * destination , const void * source , size_t num )

函数模拟实现 

void* my_memmove(void* dest,void* str , size_t count)
{
	void* ch = dest;
	if (dest > str)
	{
		while (count--)
		{
			*((char*)dest + count) = *((char*)str + count);
		}
	}
	else
	{
		while (count--)
		{
			*(char*)dest = *(char*)str;
			dest=(char*)dest+1;
			str=(char*)str+1;
		}
	}
}
int main()
{
	int arr1[10] = {1,2,3,4,5,6,7,8,9,10};
	my_memmove(arr1+2, arr1 , 20);
	int sz = sizeof(arr1) / sizeof(arr1[0]);
	for (int i = 0; i < sz; i++)
	{
		printf("%d", arr1[i]);
	}
	return 0;
}

9.memcmp 

int memcmp ( const void * ptr1 , const void * ptr2 , size_t num );

 函数模拟实现

void* my_memcmp(char* arr, char* arr1, int count)
{
	while (count--)
	{
		if (*(char*)arr > *(char*)arr1)
		{
			return 1;
		}
		else if ((*(char*)arr < *(char*)arr1))
		{
			return -1;
		}
		arr++; arr1++;
	}	return 0;
}
int main()
{
	int arr[] = { 1,2,3,4,5 };
	int arr1[] = { 1,2,3,4,4 };
	int ret=my_memcmp(arr, arr1, 20);
	printf("%d", ret);
	return 0;
}

到此这篇关于C语言常用库函数的使用及模拟实现详解例举的文章就介绍到这了,更多相关C语言 库函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 基于VS2019配置opencv4.0的方法步骤

    基于VS2019配置opencv4.0的方法步骤

    这篇文章主要介绍了基于VS2019配置opencv4.0的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • 使用QPainter画一个3D正方体

    使用QPainter画一个3D正方体

    这篇文章主要为大家详细介绍了使用QPainter画一个3D正方体,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • C语言大小端模式、判断大小端、大小端转换方法详解

    C语言大小端模式、判断大小端、大小端转换方法详解

    这篇文章主要介绍了C语言大小端模式、判断大小端、大小端转换的相关资料,大端和小端是数据在内存中的存储方式,大端模式下高字节存于低地址,小端模式则相反,大小端问题由数据类型多字节存储引起,不同选择形成不同存储模式,需要的朋友可以参考下
    2024-10-10
  • C++ Primer注解之引用和指针

    C++ Primer注解之引用和指针

    这篇文章主要介绍了C++ Primer注解之引用和指针的相关知识,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • 关于C++中引用和指针的区别详解

    关于C++中引用和指针的区别详解

    这篇文章主要介绍了关于C++中引用和指针的区别详解,
    2023-07-07
  • C++无锁队列的原理与实现示例

    C++无锁队列的原理与实现示例

    C++无锁队列是一种多线程编程技术,它可以在不使用锁的情况下实现线程安全的队列,本文就来详细的介绍一下C++无锁队列的原理与实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01
  • C++中关于set删除的一些坑

    C++中关于set删除的一些坑

    这篇文章主要介绍了C++中关于set删除的一些坑,因为这个问题浪费了很多的时间,所以想着分享出来给大家,方便同样遇到这个问题的朋友们,有需要的朋友们下面来一起看看吧。
    2017-02-02
  • 关于CLion配置visual studio(msvc)和JOM多核编译的问题

    关于CLion配置visual studio(msvc)和JOM多核编译的问题

    这篇文章主要介绍了CLion配置visual studio(msvc)和JOM多核编译,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • C语言实践设计开发飞机游戏

    C语言实践设计开发飞机游戏

    飞机大战想必是很多人童年时期的经典游戏,我们依旧能记得抱个老人机娱乐的场景,下面这篇文章主要给大家介绍了关于如何利用C语言写一个简单的飞机大战小游戏的相关资料,需要的朋友可以参考下
    2022-02-02
  • C++详细讲解内存管理工具primitives

    C++详细讲解内存管理工具primitives

    文章向大家介绍C++内存管理primitives,主要包括primitives使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下
    2022-06-06

最新评论