内存操作函数

内存操作函数

1、memset() 主要用于清0

/*#include <string.h>
void *memset(void *s, int c, size_t n);
功能:将s的内存区域的前n个字节以参数c填入
参数:
   s:需要操作内存s的首地址
   c:填充的字符,c虽然参数为int,但必须是unsigned char , 范围为0~255
   n:指定需要设置的大小
返回值:s的首地址
*/
#include <stdio.h>
#include <string.h>

int main()
{
   int b[10] = {0};
   
   //处理一些代码,把b内部的元素改了
   
   
   //b[10] = {0}; //err
   int i = 0;
   int n = sizeof(b)/sizeof(b[0]);
   for(i = 0; i < n; i++)
   {
   	b[i] = 0;
   }
   
   memset(b, 0, sizeof(b) );
   
   
   char str[10];
   memset(str, 'a', sizeof(str) );
   for(i = 0; i < 10; i++)
   {
   	printf("%c, ", str[i]);
   }
   printf("\n");
   
   
   return 0;
}


int main01(int argc, char *argv[])
{
   int a;
   memset(&a, 0, sizeof(a) ); //常用
   printf("a = %d\n", a);
   
   //中间参数虽然是整型,但是以字符处理
   memset(&a, 97, sizeof(a) );
   printf("a1 = %c\n", a);
   
   
   int b[10];
   memset(b, 0, sizeof(b));
   memset(b, 0, 10 * sizeof(int));


   return 0;
}

2、memcpy() 不会因为’\0’就提前结束

/*
#include <string.h>
void *memcpy(void *dest, const void *src, size_t n);
功能:拷贝src所指的内存内容的前n个字节到dest所值的内存地址上。
参数:
	dest:目的内存首地址
	src:源内存首地址,注意:dest和src所指的内存空间不可重叠
	n:需要拷贝的字节数
返回值:dest的首地址
*/
#include <stdio.h>
#include <string.h>

int main()
{
	int a[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
	int b[10];
	
	//第3个参数是指拷贝内存的总大小
	memcpy(b, a, 10 * sizeof(int) );
	memcpy(b, a, sizeof(a) );
	
	//使用memcpy()最好别出现内存重叠
	//如果出现内存重叠,最好使用memmove
	//memcpy(&a[2], a, 5*sizeof(int) ); //err
	memmove(&a[2], a, 5*sizeof(int) );
	
	return 0;
}


int main01(int argc, char *argv[])
{
	char p[] = "hello\0mike"; //以字符串初始化,自动默认隐藏一个结束符'\0';
	char buf[100];
	printf("sizeof(p) = %lu\n", sizeof(p));
	strncpy(buf, p, sizeof(p));
	printf("buf1 = %s\n", buf);
	printf("buf2 = %s\n", buf + strlen("hello") + 1);
	
	memset(buf, 0, sizeof(buf) );
	memcpy(buf, p, sizeof(p));
	printf("buf3 = %s\n", buf);
	printf("buf4 = %s\n", buf + strlen("hello") + 1);


	return 0;
}
  1. memmove()

memmove()功能用法和memcpy()一样,区别在于:dest和src所指的内存空间重叠时,memmove()仍然能处理,不过执行效率比memcpy()低些。

  1. memcmp()
/*
#include <string.h>
int memcmp(const void *s1, const void *s2, size_t n);
功能:比较s1和s2所指向内存区域的前n个字节
参数:
	s1:内存首地址1
	s2:内存首地址2
	n:需比较的前n个字节
返回值:
	相等:=0
	大于:>0
	小于:<0
*/
#include <stdio.h>
#include <string.h>


int main(int argc, char *argv[])
{
	int a[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
	int b[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 11};
	int flag = memcmp(a, b, 10 * sizeof(int) );
	if(flag < 0)
	{
		printf("a < b\n");
	}
	else if(flag > 0)
	{
		printf("a > b\n");
	}
	else
	{
		printf("a == b\n");
	}

	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值