博客
关于我
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/

你可能感兴趣的文章
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
查看>>
NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从Oracle11G同步数据到Mysql_亲测可用_解决数据重复_数据跟源表不一致的问题---大数据之Nifi工作笔记0065
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>