C语言模拟实现str系列函数

1.实现strcpy

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

char *my_strcpy(char *dest, const char *src){
char *ret = dest;
assert(dest != NULL);
assert(src != NULL);
while ((*dest++ = *src++)){
;
}
return ret;

}
int main(){
char src[] = "adsdsadas";
char dest[23] = "";
my_strcpy(dest, src);
printf("%s", my_strcpy(dest, src));
system("pause");

}

标题2.实现strcat

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
char *my_strcat(char *dest, char *src){

	char *ret = dest;

	assret(dest != NULL);
	assert(src != NULL);
	while (*dest){
		dest++;
	}
	while ((*dest++ = *src++)){

		;
	}
	return ret;
}
int main(){
	char str1[] = "asddsa";
	char str2[23] = "ABCD";
	my_strcat(str1, str2);
	printf("%s", my_strcat(str1, str2));
	system("pause");
}


3.实现strstr

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
char *my_strstr(const char*str1, const char*str2){

assert(str1 != NULL);
assert(str2 != NULL);
char *cp = (char*)str1;
char *substr = (char *)str2;
char *s1 = NULL;
if (*str2 == "\0"){

return 0;
}
while (*cp){
s1 = cp;
substr = str2;
while (*s1 && *substr && ( *s1  == *substr)){
s1++;
substr++;

}
if (*substr == '\0')
{
return cp;
}

cp++;

}
}
int main(){
char *str1= "asddsaABCD";
char *str2= "ABCD";
char *ret= my_strstr(str1, str2);
printf("%s", ret);
system("pause");
}

4.实现strchr

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
int my_strchr(char *src, char *dst){
char *cp = src;
char *s1 = dst;
assert(*src != NULL);
assert(*dst != NULL);
while (*cp) {
while (*s1 == *cp){

return cp;

}
cp++;
}
}
int main(){
char *str1 = "asddsaABCDrtr";
char *str2 = "A";
char *ret = my_strchr(str1, str2);
printf("%s", ret);
system("pause");
}

5.实现strcmp

#include <stdio.h>
int my_strcmp(const char *src, const char *dst){
int ret = 0;
while (!(ret = *(unsigned char *)src - *(unsigned char *)dst) && *dst){
++src;
++dst;
}
if (ret < 0){
ret = -1;
}
else if (ret>0){

ret = 1;
}
return (ret);

}
int main(){
char *src = "adsadd";
char *dst = "adfaffa";

printf("%d",my_strcmp(src, dst));
system("pause");
return 0;
}

#include <stdio.h>
int main(){
const char *str1 = "abcdef";
const char*str2 = "bbb";
if (strlen(str1) - strlen(str2) > 0){

printf("str1>str2");

}
else
{
printf("str2>str1");
}
system("pause");

return 0;
}

6.实现memcpy

#include <stdio.h>
#include <stdlib.h>
char *my_memcpy(char  *dst, const char  *src, size_t count)
{
char *ret = dst;
while (count--){
*dst =*src;
dst = dst + 1;
src = src + 1;
}
return ret;
}
int main(){
char *src = "adjsjsfkaka";
char dst[23] = "";
my_memcpy(dst, src, 3);
printf("%s", my_memcpy(dst, src, 3));
system("pause");
}
er:
#include <stdio.h>
#include <stdlib.h>
char *my_memcpy(char *dst, char *src, int num){
	int i = 0;
	while (num--)  {
		dst[i] = *src;
		src++;
		i++;
	}
	return dst;
}
int main(){
	char src[] = "asddsaABCDrtr";
	char dst[23] = "";
	char *ret = my_memcpy(dst, src, 3);
	printf("%s", ret);
	system("pause");
}

7.实现memmove

#include<stdio.h>

char *my_memmove(char *dst, char *src, size_t count){
char *ret = dst;

if (dst < src || dst >= src + count){
while (count--){
*dst = *src;
dst++;
src++;
}
}
else if (dst<src + count&&dst>src)
{
dst = dst + count - 1;
src = src + count - 1;
while (count--){
*dst= *src;
src--;
dst--;
}
}
return ret;
}
int main(){
char str[] = "menmove can be very useful ......";
char *ret=my_memmove(str+5, str, 11);
printf("%s", ret);
system("pause");
return 0;

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值