strlen,strcpy,strncpy,strcat,strncat等函数原型代码

			**

strlen,strcpy,strncpy,strcat,strncat等函数原型代码

**#include<stdio.h>
#include<assert.h>
size_t mystrlen(const char s){
assert(s!=NULL);
size_t len=0;
for(len=0;
(s+len)!=’\0’;len++);
return 0;
}

char *mystrcpy(char *dest,const char *src){
assert(dest!=NULL&&src!=NULL);
char *dpest=dest;
while((*dest++=*src++)!=’\0’);
return pdest;
}

char *mystrncpy(char *dest,const char *src,size_t n){
assert(dest!=NULL&&src!=NULL);
char *dpest=dest;
while(n–>0&&(*dest++=*src++)!=’\0’);
return pdest;
}

char *mystrcat(char *dest,const char *src){
assert(dest!=NULL&&src!=NULL);
char *pdest=dest;
while(*dest!=’\0’){
dest++;
}
while((*dest++=*src++)!=’\0’);
return pdest;
}

char *mystrncat(char *dest,const char *src,size_t n){
assert(dest!=NULL&&src!=NULL);
char pdest=dest;
while(*dest!=’\0’){
dest++;
}
while(n–>0&&(*dest++=*src++)!=’\0’);
*dest=’\0’;
return pdest;
}
char *mystrcmp(const char *s1,const char *s2){
assert(s1!=NULL&&s2!=NULL);
while(*s1!=’\0’&&*s2!=’\0’&&*s1==*s2){
s1++;
s2++;
}
return *s1-*s2;
}

char *mystrncmp(const char *s1,const char *s2,size_t n){
assert(s1!=NULL&&s2!=NULL);
while(n–>1&&*s1!=’\0’&&*s2!=’\0’&&*s1!=*s2){
s1++;
s2++;
}
return *s1-*s2;
}

void mymemcpy(void *dest,const void *src,size_t n){
assert(s1!=NULL&&s2!=NULL);
char *pdest=dest;
char *psrc=src;
while(n>0){
*pdest++=*psrc++;
n–;
}
reurrn dest;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值