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

STC32G编译代码量比STC15F小很多

[复制链接]
  • 打卡等级:偶尔看看II
  • 打卡总天数:22
  • 最近打卡:2025-05-10 10:27:32
已绑定手机

14

主题

6

回帖

214

积分

中级会员

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

使用道具 举报 送花

  • 打卡等级:偶尔看看I
  • 打卡总天数:13
  • 最近打卡:2025-05-28 09:08:49

34

主题

1094

回帖

2448

积分

荣誉版主

积分
2448
发表于 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
  • 打卡总天数:498
  • 最近打卡:2025-06-16 09:44:50
已绑定手机

14

主题

1312

回帖

3298

积分

论坛元老

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

使用道具 举报 送花

  • 打卡等级:常住居民II
  • 打卡总天数:99
  • 最近打卡:2025-06-16 09:28:47

733

主题

1万

回帖

1万

积分

管理员

积分
16651
发表于 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
  • 打卡总天数:467
  • 最近打卡:2025-06-15 22:44:24
已绑定手机

19

主题

3231

回帖

5281

积分

论坛元老

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

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:558
  • 最近打卡:2025-06-16 20:32:37

24

主题

524

回帖

1224

积分

荣誉版主

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

使用道具 举报 送花

  • 打卡等级:常住居民II
  • 打卡总天数:99
  • 最近打卡:2025-06-16 09:28:47

733

主题

1万

回帖

1万

积分

管理员

积分
16651
发表于 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
  • 打卡总天数:558
  • 最近打卡:2025-06-16 20:32:37

24

主题

524

回帖

1224

积分

荣誉版主

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

使用道具 举报 送花

  • 打卡等级:常住居民II
  • 打卡总天数:99
  • 最近打卡:2025-06-16 09:28:47

733

主题

1万

回帖

1万

积分

管理员

积分
16651
发表于 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-6-17 05:16 , Processed in 0.133487 second(s), 103 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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