找回密码
 立即注册
查看: 1819|回复: 19

STC32G编译代码量比STC15F小很多

[复制链接]
  • 打卡等级:偶尔看看II
  • 打卡总天数:21
  • 最近打卡:2025-04-18 10:17:33
已绑定手机

14

主题

6

回帖

204

积分

中级会员

积分
204
发表于 2024-2-22 17:02:43 | 显示全部楼层 |阅读模式
项目使用STC15F处理器,代码量接近58K,就换成STC32G处理器,可同一工程,STC32G编译出来的代码只有25K左右,这是为什么?
回复

使用道具 举报 送花

  • 打卡等级:初来乍到
  • 打卡总天数:5
  • 最近打卡:2025-04-30 07:46:22

33

主题

1079

回帖

2319

积分

荣誉版主

积分
2319
发表于 2024-2-22 17:59:40 来自手机 | 显示全部楼层
不知道你编绎了啥代码,如果是差不多功能的代码,出现这种情况可能是15系列使用了大量xdata,在同等情况下,访问xdata对比edata需要多一些指今
回复 支持 1 反对 0

使用道具 举报 送花

  • 打卡等级:以坛为家I
  • 打卡总天数:217
  • 最近打卡:2024-11-15 09:12:27

29

主题

722

回帖

2790

积分

荣誉版主

积分
2790
发表于 2024-2-22 18:37:48 | 显示全部楼层
本帖最后由 gentleman 于 2024-2-22 18:39 编辑

C251拓展了指令集
某些新增指令  需要很多条c51指令实现
编译后所需flash空间就缩短了

比如  ADD DRk,DRk





回复 支持 0 反对 1

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:452
  • 最近打卡:2025-05-01 06:20:50
已绑定手机

13

主题

1257

回帖

2971

积分

金牌会员

积分
2971
发表于 2024-2-22 19:29:03 | 显示全部楼层
C251和C51编译出来的HEX大小没有什么可比性,毕竟一个是32位、一个是8位。
所以对于数据处理量较大的程序来讲,用STC32还是有不小优势的。
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:偶尔看看III
  • 打卡总天数:54
  • 最近打卡:2025-05-01 09:07:55

717

主题

1万

回帖

1万

积分

管理员

积分
15613
发表于 2024-2-22 21:55:28 | 显示全部楼层
STC15, 111条指令
STC32G12K128系列,268条指令,
至少相当于 STC8/STC15的 1.15倍的代码空间效率

  64K * 1.15 = 73.46K
128K * 1.15 = 147.2K
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:422
  • 最近打卡:2025-05-01 09:54:52
已绑定手机

19

主题

3190

回帖

4866

积分

论坛元老

积分
4866
发表于 2024-3-10 18:23:20 | 显示全部楼层
指令多运行一些特定项目空间效率也高是这道理吗
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:513
  • 最近打卡:2025-05-01 04:31:49

24

主题

515

回帖

986

积分

荣誉版主

积分
986
发表于 2024-3-10 19:23:49 | 显示全部楼层
这说明KEILC51在LARGER模式下编译结果非常非常垃圾!!!!!!!!!!!!!!!!!!
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:偶尔看看III
  • 打卡总天数:54
  • 最近打卡:2025-05-01 09:07:55

717

主题

1万

回帖

1万

积分

管理员

积分
15613
发表于 2024-3-10 19:28:08 | 显示全部楼层
STC15, 111条指令
STC32G12K128系列,268条指令,
至少相当于 STC8/STC15的 1.15倍的代码空间效率

  64K * 1.15 = 73.46K
128K * 1.15 = 147.2K

回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:513
  • 最近打卡:2025-05-01 04:31:49

24

主题

515

回帖

986

积分

荣誉版主

积分
986
发表于 2024-3-10 19:31:01 | 显示全部楼层
如果用IAR C51,在LARGER模式下最多可设置32个虚拟寄存器,充分利用data空间,编译的代码量会大大降低。
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:偶尔看看III
  • 打卡总天数:54
  • 最近打卡:2025-05-01 09:07:55

717

主题

1万

回帖

1万

积分

管理员

积分
15613
发表于 2024-3-10 19:40:38 | 显示全部楼层
咋搞,51 也没法更 251的 268条指令的空间代码效率相比


STC15, 111条指令
STC32G12K128系列,268条指令,
至少相当于 STC8/STC15的 1.15倍的代码空间效率

  64K * 1.15 = 73.46K
128K * 1.15 = 147.2K


截图202403101940329816.jpg

回复 支持 反对

使用道具 举报 送花

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|深圳国芯人工智能有限公司 ( 粤ICP备2022108929号-2 )

GMT+8, 2025-5-2 07:01 , Processed in 0.128317 second(s), 120 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表