博客
关于我
memset()函数浅析
阅读量:691 次
发布时间:2019-03-17

本文共 2612 字,大约阅读时间需要 8 分钟。

在初始化数据时,尤其结构体里的数组,新手就设个i,然后来个for循环一个一个初始化为0,memset()函数就是简化了这个步骤,因为上面这个步骤你可能搞错数组长度,废话不多说,下面教你如何编写memset()及最基本常用的方法!

一、函数分析

void memset(void *src, unsigned char ch, unsigned char len){   char *psrc = (char *)src;   if(src == NULL) return;   while(len--)   {      *psrc = ch;      psrc++;   }}
1、void *src

我们在传入数据时,因为数据长度有8位,16位,32位,为了可以统一赋值,我们就取8位作为赋值的单位,这样16位我们赋值2次,32位赋值4次就可以了;所以在不知道传入的数据时什么类型的情况下,我们用void *src 来接收不同的数据;

2、char *psrc = (char *)src

将传入数据的首地址强制装换为char*类型即长度为8位的指针,因为一个8位地址对应一个8位数据;

3、len

那传入的数据可以分为多少个8位呢?这里我们用sizeof()函数计算,长度=sizeof(数据名)/sizeof(unsigned char),这样可以避免自己数错;

二、函数实战(这里只做0的赋值)

1、unsigned char类型数组清0实例

#include 
int main() { unsigned char i; unsigned char arr[]= {"我是"}; printf("原数据\n"); for(i=0;i<(sizeof(arr)/sizeof(unsigned char));i++) { printf(" =%x= ",arr[i]); } memset(arr,0,sizeof(arr)/sizeof(unsigned char)); printf("\n"); printf("处理后数据\n"); for(i=0;i<(sizeof(arr)/sizeof(unsigned char));i++) { printf(" =%x= ",arr[i]); } return 0;}
结果为:

原数据 =e6=  =88=  =91=  =e6=  =98=  =af=  =0= 处理后数据 =0=  =0=  =0=  =0=  =0=  =0=  =0=
2、unsigned int类型数组清0实例

#include 
int main() { unsigned char i; unsigned int arr[]= {0x12,0x23,0x45,0x56,0xab,0xdf}; printf("原数据\n"); for(i=0;i<(sizeof(arr)/sizeof(unsigned int));i++) { printf(" =%x= ",arr[i]); } memset(arr,0,sizeof(arr)/sizeof(unsigned char)); printf("\n"); printf("处理后数据\n"); for(i=0;i<(sizeof(arr)/sizeof(unsigned int));i++) { printf(" =%x= ",arr[i]); } return 0;}
结果为:

原数据 =12=  =23=  =45=  =56=  =ab=  =df= 处理后数据 =0=  =0=  =0=  =0=  =0=  =0=
3、typedef struct类型清0实例

#include 
typedef struct{ unsigned int a[3]; unsigned char b[2];}Example;int main() { unsigned char i; Example Struct_Arr; Struct_Arr.a[0] = 0x12; Struct_Arr.a[1] = 0xa34; Struct_Arr.a[2] = 0x1234; Struct_Arr.b[0] = 0xab; Struct_Arr.b[1] = 0xcd; printf("原数据 a\n"); for(i=0;i<(sizeof(Struct_Arr.a)/sizeof(unsigned int));i++) { printf(" =%x= ",Struct_Arr.a[i]); } printf("\n"); printf("原数据 b\n"); for(i=0;i<(sizeof(Struct_Arr.b)/sizeof(unsigned char));i++) { printf(" =%x= ",Struct_Arr.b[i]); } memset(&Struct_Arr,0,sizeof(Struct_Arr)/sizeof(unsigned char)); printf("\n"); printf("处理后a数据\n"); for(i=0;i<(sizeof(Struct_Arr.a)/sizeof(unsigned int));i++) { printf(" =%x= ",Struct_Arr.a[i]); } printf("\n"); printf("处理后b数据\n"); for(i=0;i<(sizeof(Struct_Arr.b)/sizeof(unsigned char));i++) { printf(" =%x= ",Struct_Arr.b[i]); } return 0;}
结果为:

原数据 a =12=  =a34=  =1234= 原数据 b =ab=  =cd= 处理后a数据 =0=  =0=  =0= 处理后b数据 =0=  =0=
以上就是很简单的快速清0操作,最后一个在嵌入式初始化数据很常用!!!

转载地址:http://gzkhz.baihongyu.com/

你可能感兴趣的文章
MVC 区域功能
查看>>
MySQL FEDERATED 提示
查看>>
mysql generic安装_MySQL 5.6 Generic Binary安装与配置_MySQL
查看>>
Mysql group by
查看>>
MySQL I 有福啦,窗口函数大大提高了取数的效率!
查看>>
mysql id自动增长 初始值 Mysql重置auto_increment初始值
查看>>
MySQL in 太多过慢的 3 种解决方案
查看>>
MySQL InnoDB 三大文件日志,看完秒懂
查看>>
Mysql InnoDB 数据更新导致锁表
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>
Mysql InnoDB存储引擎 —— 数据页
查看>>
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
查看>>