学习笔记----memset 介绍

本文详细介绍了memset函数的功能与使用方法,包括参数说明、示例代码及输出结果。通过实例展示了如何利用memset进行字符替换和内存初始化。

先看看帮助文档上的介绍以及实例:

Sets buffers to a specified character.

void *memset(
   void* dest, 
   int c, 
   size_t count 
);
Parameters
dest
Pointer to destination.     目标指针
c
Character to set.               ascii 字符
count
Number of characters.      字节数

Example

/* MEMSET.C: This program uses memset to
 * set the first four characters of buffer to "*".
 */

#include <memory.h>
#include <stdio.h>

void main( void )
{
   char buffer[] = "This is a test of the memset function";

   printf( "Before: %s\n", buffer );
   memset( buffer, '*', 4 );
   printf( "After:  %s\n", buffer );
}

Output

Before: This is a test of the memset function
After:  **** is a test of the memset function

在上面的例子中,字符数组buffer 的前四个字符被替换为‘*’,可见memset函数的做表面作用就是字符替换。

有一个比较好的功能描述:将指定的内存块中的每个字节的内容设置成指定的ACSII字符

memset 最常见的功能就是为新申请的内存做初始化,

比如在C++中:

char  buff[100];

memset(buff,0,sizeof(buff));  

或者 memset(buff,'/0',100) 

或者 memset(buff,' ',sizeof(char)*100)


操作结构也是一样的

structsample_struct
{
       char csName[16];
       int iSeq;
       int iType;
} ;

对于变量
struct sample_strcut stTest
用memset就非常方便:
memset(&stTest,0,sizeof(struct sample_struct));

如果是数组:
struct sample_struct TEST[10];

memset(TEST,0,sizeof(struct sample_struct)*10);






#include <windows.h> #include <winsock.h> #include <assert.h> #include <iostream> #include <string> #include <stdio.h> #include <ctime> #pragma comment(lib,"WS2_32.lib") using namespace std; //base64编码 string Base64Encode(LPCTSTR lpszSrc); //base64解码 string Base64Decode(LPCTSTR lpszSrc); int main() { //1.首先需要连接邮件服务器 这里用socket 邮件服务器端口 25 WSADATA Wsa; //进行WINSOCK的设置 WSAStartup(0x0101,&Wsa); SOCKET s = socket(AF_INET,SOCK_STREAM,IPPROTO_IP); SOCKADDR_IN sin; LPHOSTENT lphost = gethostbyname("smtp.163.com");//这里是用网易的邮件服务器 也可以修改 if(lphost) sin.sin_addr.s_addr = ((LPIN_ADDR)lphost->h_addr)->s_addr; else { printf("%s\n","获取地址失败"); return 1; } sin.sin_family = AF_INET; //注意邮件服务器的侦听端口 25 sin.sin_port = htons(IPPORT_SMTP); //连接服务器 if(connect(s,(LPSOCKADDR)&sin,sizeof(sin))==SOCKET_ERROR) { printf("%s\n","连接错误"); return 1; } printf("%s\n","连接成功"); //接收服务器初次回应 char buff[1024]; memset(buff,0,sizeof(buff)); recv(s,buff,sizeof(buff),0); printf("服务说:%s\n",buff); /////上面已经完成连接了///// string szLine="\r\n";//相当于你按下回车 //2.现在就是和服务器对话了 //问候服务器 string szHelo = "HELO smtp.163.com" + szLine; printf("我说:%s\n",szHelo.c_str()); send(s,szHelo.c_str(),szHelo.length(),0); memset(buff,0,sizeof(buff)); recv(s,buff,sizeof(buff),0); printf("服务说:%s\n",buff); //请求验证用户密码(需要编码) string szAL = "auth login" + szLine; //发送验证命令 printf("我说:%s\n",szAL.c_str()); send(s,szAL.c_str(),szAL.length(),0); memset(buff,0,sizeof(buff)); recv(s,buff,sizeof(buff),0); // printf("服务说:%s\n",buff); //服务器会回答说 可以输入帐号 //发送帐号 string szUser; cout<<Base64Decode((LPCTSTR)(buff+4)); cin>>szUser; szUser = Base64Encode(szUser.c_str()) + szLine; //对输入的帐号进行base64编码 send(s,szUser.c_str(),szUser.length(),0); //发送帐号 printf("我说:%s\n",szUser.c_str()); memset(buff,0,sizeof(buff)); recv(s,buff,sizeof(buff),0); // printf("服务说:%s\n",buff); //服务器会回答说 可以输入密码 //发送密码 string szPsw; cout<<Base64Decode((LPCTSTR)(buff+4)); cin>>szPsw; szPsw = Base64Encode(szPsw.c_str()) + szLine; //对输入的密码进行base64编码 send(s,szPsw.c_str(),szPsw.length(),0); //发送密码 printf("我说:%s\n",szPsw.c_str()); memset(buff,0,sizeof(buff)); recv(s,buff,sizeof(buff),0); printf("服务说:%s\n",buff); //然后可以用你登陆的邮箱给其他邮箱发邮件了 string szFrom,szTo; cout<<"from:";//你自己的邮箱 cin>>szFrom; cout<<"to:"; //发送给谁 cin>>szTo; //发送者的地址 string From = "mail from:<"+szFrom+ ">"+ szLine; //收信者地址 string To = "rcpt to:<" + szTo +">" + szLine; //现在确定看谁发的邮件 往哪发 send(s,From.c_str(),From.length(),0);//from printf("我说:%s\n",From.c_str()); memset(buff,0,sizeof(buff)); recv(s,buff,sizeof(buff),0); printf("服务说:%s\n",buff); getchar(); //只是用来暂停一下而已 按任意字母继续 send(s,To.c_str(),To.length(),0); //to printf("我说:%s\n",To.c_str()); memset(buff,0,sizeof(buff)); recv(s,buff,sizeof(buff),0); printf("服务说:%s\n",buff); getchar(); //资料应该都看过了吧命令里的data输入后 表示输入邮件内容了 send(s,"data\r\n",6,0); //DATA 命令发送 printf("我说:%s\n","data"); memset(buff,0,sizeof(buff)); recv(s,buff,sizeof(buff),0); printf("服务说:%s\n",buff); //邮件 下面的信息都是当作内容处理 //邮件头 string szFrom_in = "from:"+szFrom + szLine; string szTo_in = "to:"+szTo + szLine; //发送日期 string szDate_in="Date: Sat, 20 Aug 2011 13:39:29 +0800" + szLine;//这里我就直接写上去日期了 为了方便 //邮件标题 string szSubject_in = "Subject:我是邮件标题" + szLine; //邮件正文 string szBody_in = "我就是传说中的邮件体" + szLine; string szContent = szFrom_in + szTo_in + szDate_in + szSubject_in; szContent += szLine;//添加一个空白行 szContent += szBody_in; //上面是最基本的格式// send(s,szContent.c_str(),szContent.length(),0); //szContent printf("我说:%s\n",szContent.c_str()); memset(buff,0,sizeof(buff)); // recv(s,buff,sizeof(buff),0); // printf("服务说:%s\n",buff); getchar(); //发送完了说明下结束 send(s,".\r\n",3,0); //说明内容结束了 printf("我说:%s\n","."); memset(buff,0,sizeof(buff)); recv(s,buff,sizeof(buff),0); printf("服务说:%s\n",buff); getchar(); //退出服务器连接 send(s,"quit\r\n",6,0); //退出 printf("我说:%s\n","quit"); memset(buff,0,sizeof(buff)); recv(s,buff,sizeof(buff),0); printf("服务说:%s 发送邮件成功\n",buff); return 0; } 等等。
### InvenSense 传感器技术文档与驱动开发 InvenSense 是一家专注于 MEMS 传感器和运动处理解决方案的公司,其技术广泛应用于智能手机、物联网设备以及其他消费电子领域。TDK 收购 InvenSense 后,进一步推动了 MEMS 技术在智能设备中的应用[^1]。 #### 技术文档 InvenSense 提供了一系列技术文档,帮助开发者深入了解其传感器的功能和使用方法。这些文档包括但不限于: - **数据手册(Datasheets)**:详细描述传感器的规格、性能参数以及电气特性。 - **应用笔记(Application Notes)**:提供特定应用场景下的实现指南和技术建议。 - **参考设计(Reference Designs)**:为开发者提供经过验证的硬件和软件设计方案。 - **固件更新说明(Firmware Update Notes)**:介绍如何升级传感器固件以获得最新功能或修复已知问题。 #### 驱动开发 对于基于 Linux 系统的开发环境,InvenSense 传感器的驱动开发通常遵循标准的 Linux 驱动框架。以下是一个典型的驱动开发流程: 1. **硬件连接**:根据具体的传感器型号和主控芯片,完成引脚连接。例如,ICM-20608 传感器通过 SPI 接口与 i.MX6ULL 主控相连时,需要配置相应的引脚映射[^3]。 2. **设备树配置**:在设备树中添加传感器节点,定义通信接口(如 SPI 或 I2C)、中断引脚以及其他必要的参数。 ```dts &spi3 { status = "okay"; cs-gpios = <&gpio7 14 GPIO_ACTIVE_LOW>; /* ECSPI3_SS0 */ spi@0 { compatible = "invensense,icm-20608"; reg = <0>; interrupts = <25 0>; /* Example interrupt pin */ }; }; ``` 3. **驱动程序编写**:实现传感器的驱动程序,包括初始化、数据读取等功能。以下是一个简单的 SPI 数据读取示例代码[^2]: ```c #include <linux/spi/spi.h> #include <linux/module.h> #include <linux/kernel.h> static int icm20608_spi_read(struct spi_device *spi, u8 reg, u8 *data, size_t len) { struct spi_message msg; struct spi_transfer xfer[2]; u8 cmd = reg | 0x80; // Set read bit spi_message_init(&msg); memset(xfer, 0, sizeof(xfer)); xfer[0].tx_buf = &cmd; xfer[0].len = 1; spi_message_add_tail(&xfer[0], &msg); xfer[1].rx_buf = data; xfer[1].len = len; spi_message_add_tail(&xfer[1], &msg); return spi_sync(spi, &msg); } static int __init icm20608_spi_probe(struct spi_device *spi) { u8 buffer[6]; int ret; ret = icm20608_spi_read(spi, 0x00, buffer, sizeof(buffer)); if (ret < 0) { pr_err("Failed to read from sensor\n"); return ret; } pr_info("Sensor data: %02x %02x %02x %02x %02x %02x\n", buffer[0], buffer[1], buffer[2], buffer[3], buffer[4], buffer[5]); return 0; } static const struct of_device_id icm20608_of_match[] = { { .compatible = "invensense,icm-20608", }, { /* end of list */ } }; MODULE_DEVICE_TABLE(of, icm20608_of_match); static struct spi_driver icm20608_spi_driver = { .driver = { .name = "icm20608_spi", .of_match_table = icm20608_of_match, }, .probe = icm20608_spi_probe, }; module_spi_driver(icm20608_spi_driver); MODULE_AUTHOR("Your Name"); MODULE_DESCRIPTION("ICM-20608 SPI Driver"); MODULE_LICENSE("GPL"); ``` 4. **测试与调试**:通过加载驱动模块并运行测试程序,验证传感器是否能够正常工作。 #### 相关资源 - InvenSense 官方网站提供了丰富的技术文档和支持工具。 - 开源社区(如 GitHub)中有许多针对 InvenSense 传感器的驱动代码示例,可供参考和学习。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值