C语言:内存函数

目录

1.memcpy

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

  • 函数memcpy从source的位置开始向后复制num个字节的数据到destination指向的内存位置
  • 这个函数再遇到\0时不会停下来
  • 如果source和destination有任何的重叠,复制的结果都是未定义的(也就是说memcpy函数最好在两个不同的数组之间拷贝)
c 复制代码
int main() {
	int a[] = { 1,2,3,4,5 };
	int b[10] = { 0 };
	memcpy(b, a, 20);

	for (int i = 0; i < 10; i++) {
		printf("%d ", b[i]);
	}
}


模拟实现

c 复制代码
void my_memcpy(void* b, const void* a, int n) {
	assert(a && b);
	while (n--) {
		*(char*)b = *(char*)a;
		b = (char*)b + 1;
		a = (char*)a + 1;
	}
	*(char*)b = '\0';
}
int main() {
	char a[] = "Hello";
	char b[100];
	int n = 5 * sizeof(a[0]);
	my_memcpy(b, a, n);

	printf("%s\n", b);
	return 0;
}

注意count时字节数,因为memcpy函数的第三个参数是需要复制的字节数,因为int类型的字节数时4个字节,所以需要复制5个元素的话就需要20个字节。

2.memmove

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

  • memmove和memcpy都是起到的复制的作用,不同点是memmove函数可以处理的原内存块和目标内存的块是可以重叠的

  • 如果要处理的原空间和目标空间出现重叠,那么必须使用memmove函数进行处理

c 复制代码
int main() {
	int a[] = { 1,2,3,4,5,6,7,8,9,10 };
	memmove(a + 2, a, 20);
	for (int i = 0; i < 10; i++) {

		printf("%d ", a[i]);
	}

	return 0;
}

3.memset

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

  • memset函数是用来设置内存的,将内存中的值以字节为单位设置为想要的内容
  • memset函数最好不处理多字节的数据类型,比如int, double, long......
c 复制代码
int main() {
	char a[] = "Hello, Paisi";
	memset(a, 'x', 5);
	printf("%s\n", a);

	return 0;
}

4.memcmp

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

  • memcmp函数的作用时比较从ptr1和ptr2指针指向的位置开始,向后的num个字节
  • 如果ptr1 < ptr2, 则返回小于0的数
  • 如果ptr1 > ptr2,则返回大于0的数
  • 如果两个指针相等,则返回0
  • 比较的是对应位置上的ASCII码值的大小
c 复制代码
int main() {
	char a[] = "Hello, Paisi";
	char b[] = "Hello, paisi";

	int ret = memcmp(a, b, sizeof(a));
	printf("%d\n", ret);

	return 0;
}

5.atoi

int atoi (const char * str);

  • atoi函数是用于将字符串转换为整数。它的名字是 "ASCII to Integer" 的缩写。这个函数定义在 <stdlib.h> 头文件中。
c 复制代码
#include <stdio.h>  
#include <stdlib.h>  
  
int main() {  
    const char *str = "12345";  
    int number = atoi(str);  
    printf("The number is: %d\n", number);  
    return 0;  
}

模拟实现

c 复制代码
int my_atoi(const char* a) {
	int sign = 1;//定义正负号
	int result = 0;
	//去除空白字符
	while (isspace(*a)) {
		a++;
	}
	//处理符号
	if (*a == '-') {
		sign = -1;
		a++;
	}
	else if (*a == '+') {
		a++;
	}
	//处理数字
	while (isdigit(*a)) {
		int digit = *a - '0';//将数字字符转化为数字只需要减去字符0,因为ASCII码相减就是数字
		result = result * 10 + digit;
		a++;
	}
	return sign * result;
}
int main() {
	char a[] = "12345";
	int ret = my_atoi(a);
	printf("%d\n", ret);
	return 0;
}

/考研势在必行/

相关推荐
皮皮林5511 小时前
IDEA 源码阅读利器,你居然还不会?
java·intellij idea
卡尔特斯5 小时前
Android Kotlin 项目代理配置【详细步骤(可选)】
android·java·kotlin
白鲸开源5 小时前
Ubuntu 22 下 DolphinScheduler 3.x 伪集群部署实录
java·ubuntu·开源
ytadpole5 小时前
Java 25 新特性 更简洁、更高效、更现代
java·后端
纪莫5 小时前
A公司一面:类加载的过程是怎么样的? 双亲委派的优点和缺点? 产生fullGC的情况有哪些? spring的动态代理有哪些?区别是什么? 如何排查CPU使用率过高?
java·java面试⑧股
JavaGuide6 小时前
JDK 25(长期支持版) 发布,新特性解读!
java·后端
用户3721574261356 小时前
Java 轻松批量替换 Word 文档文字内容
java
白鲸开源6 小时前
教你数分钟内创建并运行一个 DolphinScheduler Workflow!
java
Java中文社群7 小时前
有点意思!Java8后最有用新特性排行榜!
java·后端·面试
代码匠心7 小时前
从零开始学Flink:数据源
java·大数据·后端·flink