內存處理函數(課堂代碼)

比特6.12課堂代碼

  1. 代碼需要分段解引用
  2. 頭文件
#ifndef _TEST_H_
#define _TEST_H_

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <Windows.h>
#include <math.h>
#include <time.h>
#include <assert.h>
#include <errno.h>










#endif // !_TEST_H所有變量聲明
//#include "58.h"


////模擬實現strcmp
//
//int My_strcmp(const char* str1, const char* str2)
//{
//	int ret = 0;//保存結果
//	while (!(ret = (unsigned char)*str1 - (unsigned char)*str2 && *str1))
//	{
//		str1++;
//		str2++;
//	}
//	return ret;
//}
//int main()
//{
//	char str1[N] = "Hello World!";
//	char str2[N] = "Hello WorlD!";//大寫字母 ASCII 碼值小,str2 應該小於 str2
//
//	int ret = My_strcmp(str1, str2);
//	if (0 == ret)
//	{
//		printf("兩個字符串相等\n");
//	}
//	else if (ret > 0)
//	{
//		printf("字符串\" %s \" > 字符串\" %s \"\n", str1, str2);
//	}
//	else if (ret < 0)
//	{
//		printf("字符串\" %s \" < 字符串\" %s \"\n", str1, str2);
//	}
//	else
//	{
//		printf("不會出現,到這就完蛋了\n");
//	}
//	return EXIT_SUCCESS;
//}




////模擬strcat
//char * My_strcat(char str1[32], const char* str2)
//{
//	assert(str1);
//	assert(str2);
//
//	char* ret = str1;
//	while (*str1)
//	{
//		str1++;
//	}
//	while (*str1++ = *str2++);
//	return ret;
//}
//int main()
//{
//	char s1[32] = "Hello ";
//	const char* s2 = "world";
//
//	My_strcat(s1, s2);
//	puts(s1);
//	return EXIT_SUCCESS;
//}



////模擬 strcpy
//void My_strcpy(char* str1, const char* str2)
//{
//	assert(str2);
//
//	//3
//	//while (*str1++ = *str2++)
//	//	;
//
//	//2
//	//while (*str1 != '\0')
//	//{
//	//	*str1 = *str2;
//	//	str1++;
//	//	str2++;
//	//}
//
//	//1
//	//while (*str1 = *str2)
//	//{
//	//	str1++;
//	//	str2++;
//	//}
//}
//int main()
//{
//	char s1[32] = "uisjuedygeda";
//	char s2[32] = "hello world";
//
//	printf("%s\n%s\n\n", s1, s2);
//	My_strcpy(s1, s2);
//	printf("%s\n%s\n\n", s1, s2);
//
//	return EXIT_SUCCESS;
//}



////模擬strlen
//
//size_t My_strlen(const char* str)
//{
//	//1
//	assert(str);
//	//size_t count = 0;
//	//while (*str)
//	//{
//	//	str++;
//	//	count++;
//	//}
//	//return count;
//
//
//	//2
//	//const char* start = str;
//	//const char* end = str;
//	//while (*end)
//	//{
//	//	end++;
//	//}
//	////end 指向 \0
//	//return end - start;
//
//
//
//	//3
//	//if (*str == '\0')
//	//{
//	//	return 0;
//	//}
//	//return 1 + My_strlen(str + 1);
//}
//int main()
//{
//	const char* s1 = "hello world";
//	printf("%u\n", My_strlen(s1));
//
//	return EXIT_SUCCESS;
//}







////memcmp
////memset
//int main()
//{
//	//char* s1 = "12355";
//	//char* s2 = "12345";
//	//printf("%d\n", memcmp(s1, s2, 5));
//
//
//	int a[10];
//	memset(a, 0, sizeof(a));
//	int i = 0;
//	for (; i < 10; i++)
//	{
//		printf("%4d", a[i]);
//	}
//	return EXIT_SUCCESS;
//}


////模擬memmove
////與類型無關-->類型轉換
//void* My_memmove(void* dst, const void* src, size_t num)
//{
//	assert(dst);
//	assert(src);
//
//
//	const char* src_p = (char*)src;
//	char* dst_p = (char*)dst;
//
//
//	if (dst_p > src_p && dst_p < num + src_p)
//	{
//		src_p = src_p + num - 1;//指向最後一個有效位置
//		dst_p = dst_p + num - 1;
//		while (num > 0)
//		{
//			*dst_p = *src_p;
//			dst_p--;
//			src_p--;
//			num--;
//		}
//		return dst;
//	}
//	else
//	{
//		while (num > 0)
//		{
//			*dst_p = *src_p;
//			dst_p++;
//			src_p++;
//			num--;
//		}
//		return dst;
//	}
//}
//int main()
//{
//	char str[32] = "oiisijijduv";
//	char dst[32];
//	size_t len = strlen(str) + 1;
//	//My_memmove(dst, str, len);
//	//My_memmove(str, str + 3, len);
//
//	My_memmove(str + 3, str, len);//錯誤
//	puts(str);
//	return EXIT_SUCCESS;
//}




////memcopy   內存複製
////memmove   複製的過程就好比是第二個實參中的字節先被複制到一個臨時的字符數組中,
////          然後再從這個臨時數組複製到第一個實參中
//
//struct Stu {
//	char name[16];
//	int age;
//	char sex[8];
//};
//int main()
//{
//	//struct Stu Tom = { "Tom",19,"男" };
//	//struct Stu Tom_copy;
//	//memcpy(&Tom_copy, &Tom, sizeof(Tom));
//	//printf("%s   %d    %s\n", Tom.name, Tom.age, Tom.sex);
//	//printf("%s   %d    %s\n", Tom_copy.name, Tom_copy.age, Tom_copy.sex);
//
//	//char str[32] = "abcdefg123456";
//	//int len = strlen(str);
//	//printf("%s\n", str);
//	//memmove(str + 3, str, len);
//	//printf("%s\n", str);
//	//memmove(str, str + 3, len);
//	//printf("%s\n", str);
//	return EXIT_SUCCESS;
//}
  • memmove模擬圖解

在這裏插入圖片描述

  1. 函數 memcpy 將第二個實參所指對象中指定數目的字符複製到第一個實參所指的對象中。該函數可以接收指向任意類型對象的指針作爲實參
  2. 函數memmove將第二個實參所指對象中指定數目的字節複製到第一個實參所指向的對象中。複製的過程就好比是第二個實參中的字節先被複制到一個臨時的字符數組中,然後再從這個臨時數組複製到第一個實參中
  3. 函數memcmp將第一個實參與第二個實參中指定數目的字節進行比較
  4. 函數memchr在一個對象的指定數目的字節中,查找一個表示爲 unsigned char 的單字節數據首次出現的位置。若找到此字節,則函數返回指向該字節的指針,否則函數返回NULL
  5. 函數memset將第二個實參,當成一個無符號字符,複製到第一個實參所指對象的指定數目的字節中
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章