完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
TASKING 编译器是否可以将数据结构设置为 "打包"? GCC 很早以前就提供了这种可能性,可以将__attribute__((packed))与对齐指令结合使用。 对于从外部组件收集数据(例如通过 I2C 或 SPI 接收),这非常有帮助,因为它们通常是按字节(甚至按位)组织的(我知道的大多数EVAL_PASCO2_SENSOR )。 因此,如果微控制器将这些数据复制到相应的数据结构中,应用程序就可以节省解包时间。
是的,我知道访问打包数据结构在内存访问时间性能方面并非最佳。 不过,至少在我的应用中,对这种打包结构的访问频率在 1-1000Hz 之间,而微控制器的执行频率为 300MHZ。 因此,与应用程序内存访问相比,这种内存访问很少发生。 不要忘了,解压缩也需要时间,而且通常只有在每次收到新数据时才需要访问已收到的数据。 因此,"非最佳对齐内存访问 "的次数大致相同,但应用程序不需要解包功能。 |
|
相关推荐
1个回答
|
|
TASKING编译器确实可以使用“打包”(packed)属性来将数据结构设置为按字节对齐,以便节省内存。使用__attribute__((packed))可以告诉编译器取消对数据结构进行默认的对齐,而使用紧凑的排列。
相比之下,GCC编译器也提供了类似的功能,通过__attribute__((packed))来实现数据结构的紧凑排列。 对于从外部组件收集的数据,使用打包的数据结构可以方便地将其复制到相应的数据结构中,以节省解包时间。然而,需要注意的是,访问打包的数据结构可能会影响内存访问时间性能。 在您的应用中,对于该打包结构的访问频率在1-1000Hz之间,这可能仍然是可接受的。然而,根据应用场景和具体要求,您可能需要评估打包数据结构对性能和内存的影响,并权衡使用打包结构和解包操作之间的优劣势。 |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
stm32f407+ksz8863rlli概率性ping不通
698 浏览 0 评论
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-常见网络服务搭建之NFS服务搭建
374 浏览 0 评论
求助:辉芒微芯片 FDM B11GBMH 的信息及开发环境安装
375 浏览 0 评论
918 浏览 0 评论
嵌入式 学习-飞凌嵌入式ElfBoard ELF 1板卡-shell脚本编写之输入输出重定向
774 浏览 0 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
11306 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-9-29 06:41 , Processed in 0.645271 second(s), Total 72, Slave 56 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号