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

你可能感兴趣的文章
Netty工作笔记0059---Netty私聊实现思路
查看>>
Netty工作笔记0060---Netty心跳机制实例
查看>>
Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
查看>>
Netty工作笔记0061---Netty心跳处理器编写
查看>>
Netty工作笔记0062---WebSocket长连接开发
查看>>
Netty工作笔记0063---WebSocket长连接开发2
查看>>
vue样式穿透 ::v-deep的具体使用
查看>>
Netty工作笔记0065---WebSocket长连接开发4
查看>>
Netty工作笔记0066---Netty核心模块内容梳理
查看>>
Vue基本使用---vue工作笔记0002
查看>>
Netty工作笔记0068---Protobuf机制简述
查看>>
Netty工作笔记0069---Protobuf使用案例
查看>>
Netty工作笔记0070---Protobuf使用案例Codec使用
查看>>
Netty工作笔记0071---Protobuf传输多种类型
查看>>
Netty工作笔记0072---Protobuf内容小结
查看>>
Netty工作笔记0073---Neety的出站和入站机制
查看>>
Netty工作笔记0074---handler链调用机制实例1
查看>>
Netty工作笔记0075---handler链调用机制实例1
查看>>
Netty工作笔记0076---handler链调用机制实例3
查看>>
Netty工作笔记0077---handler链调用机制实例4
查看>>