库函数模拟实现

一.字符串函数           

1.求字符串长度

strlen函数 (求字符串长度)

返回值,参数

size_t strlen  (const  char*  str)

遇到\0就停止 返回无符号整形 

2.长度不受限制的字符串函数                                                                                                             

strcpy (字符串拷贝)

char* strcpy (char* dest,char*sour)参数分别是目的地和源头  返回拷贝后源头的指针

源字符串必须以 '\0' 结束。
会将源字符串中的 '\0' 拷贝到目标空间

strcat (追加字符串)

char* strcat (char*dest,const char*sour)  返回源头的指针

注:不能给自己追加,容易出错
strcmp (比较字符串)

int strcmp (const char*buf1,const char * buf2)

比较俩个字符串的首元素*buf1>*buf2,返回1

                                        *buf1<*buf2,返回-1

                                         若是相等,判断下一个字符,直到‘\0’,返回0

3.长度受限制的字符串函数


strncpy(将拷贝的字符串长度传给函数)

char * strncpy ( char * destination, const char * source, size_t num )

将控制拷贝的字符串长度
strncat (追加输入数字的字符串)

char * strncat ( char * destination, const char * source, size_t num )

strncmp

int strncmp ( const char * str1, const char * str2, size_t num )
按照上面的方法,比较输入数字字符串长度

4.字符串查找


strstr (查找字符串中是否有子串)

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

找到后返回子串初始指针,找不到返回空指针

strtok(分割字符串)

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

前面参数输入按照什么字符分割的字符串,比如134141.31@124,输入以”.@“俩个字符作为分割

自动分为134141 和31和124,按照需求取。

注:
第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标
记。
strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针。(注:
strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容
并且可修改。)
strtok函数的第一个参数不为 NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串
中的位置。
strtok函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标
记。
如果字符串中不存在更多的标记,则返回 NULL 指针

5.错误信息报告
strerror

头文件#include <errno.h>

#include <stdio.h>
#include <string.h>
#include <errno.h>
int main ()
{
FILE * pFile;
pFile = fopen ("unexist.ent","r");
if (pFile == NULL)
printf ("Error opening file unexist.ent: %s\n",strerror(errno));
//errno: Last error number
return 0;
}

例如:打开文件,没有这个文件或者格式错误,将打印出错误

6.内存操作函数(都是void*内容)


memcpy 

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

按照内存复制内容

函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置。
这个函数在遇到 '\0' 的时候并不会停下来。
如果source和destination有任何的重叠,复制的结果都是未定义的。

memmove

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

和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。
如果源空间和目标空间出现重叠,就得使用memmove函数处理

注:可以给自己移动不会出现错误
memset

void * memset ( void * ptr, int value, size_t num )

修改内存中的元素,输入开始位置,输入需要改成的内容,输入改多少个内容
memcmp

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

比较从ptr1和ptr2指针开始的num个字节

大于返回1,小于返回-1,等于向后比,直到全部比完任然相等返回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~z或A~Z
isalnum字母或者数字,a~z,A~Z,0~9
ispunct标点符号,任何不属于数字或者字母的图形字符(可打印)
isgraph任何图形字符
isprint任何可打印字符,包括图形字符和空白字符

判断是否为控制字符中的内容,是返回1,不是返回0。

8.字符转换

tolower 函数
int tolower ( int c );

将字符转换为小写

toupper 函数
int toupper ( int c );

将字符转换为大写
 


 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值