完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
TASKING 编译器是否可以将数据结构设置为 "打包"? GCC 很早以前就提供了这种可能性,可以将__attribute__((packed))与对齐指令结合使用。 对于从外部组件收集数据(例如通过 I2C 或 SPI 接收),这非常有帮助,因为它们通常是按字节(甚至按位)组织的(我知道的大多数EVAL_PASCO2_SENSOR )。 因此,如果微控制器将这些数据复制到相应的数据结构中,应用程序就可以节省解包时间。
是的,我知道访问打包数据结构在内存访问时间性能方面并非最佳。 不过,至少在我的应用中,对这种打包结构的访问频率在 1-1000Hz 之间,而微控制器的执行频率为 300MHZ。 因此,与应用程序内存访问相比,这种内存访问很少发生。 不要忘了,解压缩也需要时间,而且通常只有在每次收到新数据时才需要访问已收到的数据。 因此,"非最佳对齐内存访问 "的次数大致相同,但应用程序不需要解包功能。 |
|
相关推荐
1个回答
|
|
TASKING编译器确实可以使用“打包”(packed)属性来将数据结构设置为按字节对齐,以便节省内存。使用__attribute__((packed))可以告诉编译器取消对数据结构进行默认的对齐,而使用紧凑的排列。
相比之下,GCC编译器也提供了类似的功能,通过__attribute__((packed))来实现数据结构的紧凑排列。 对于从外部组件收集的数据,使用打包的数据结构可以方便地将其复制到相应的数据结构中,以节省解包时间。然而,需要注意的是,访问打包的数据结构可能会影响内存访问时间性能。 在您的应用中,对于该打包结构的访问频率在1-1000Hz之间,这可能仍然是可接受的。然而,根据应用场景和具体要求,您可能需要评估打包数据结构对性能和内存的影响,并权衡使用打包结构和解包操作之间的优劣势。 |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-开发板适配之I2C-温湿度传感器
623 浏览 0 评论
《DNESP32S3使用指南-IDF版_V1.6》第四十六章 SD卡模拟U盘实验
603 浏览 0 评论
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-移植前准备之git管理内核源码
2050 浏览 0 评论
【瑞萨RA2L1入门学习】+ MacOS安装e2studio
959 浏览 0 评论
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-本地仓库管理之分支间的操作
863 浏览 0 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
12298 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-2-12 20:15 , Processed in 0.563895 second(s), Total 71, Slave 55 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191