找回密码
 立即注册
查看: 346|回复: 6

软件嵌套级数

[复制链接]
  • 打卡等级:常住居民III
  • 打卡总天数:138
  • 最近打卡:2025-05-01 23:08:49
已绑定手机

54

主题

39

回帖

832

积分

高级会员

积分
832
发表于 2024-9-27 10:41:28 | 显示全部楼层 |阅读模式



使用Keil的C251开发 STC32G12K128,软件 嵌套 级数有限制吗?调用子程序 8级以后出现一些问题

回复

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:425
  • 最近打卡:2025-05-03 00:09:43
已绑定手机

77

主题

4850

回帖

8388

积分

超级版主

DebugLab

积分
8388
发表于 2024-9-27 10:46:20 | 显示全部楼层
1.对任何标准类型数据的访问,其间接访问级数最大为19级。这包括数组下标,间接操作符等

2.名称长度最长不超过256字符。C语言中函数及变量名称区分大小写。但是出于兼容的原因,所有在目标文件(object file)中的名字都以大写字母出现,因此在程序中引用一个外部符号名称时大小写无关。

3.swtich语句的case的数量并没有限定,但是受有效的内存空间及单个函数所允许最大的长度限定。

4.函数参数列表中的函数的嵌套调用层数最多为10层。

5.包含文件最多可嵌套9层。

6.条件预处理最多20层,这是预处理器的限制。

7.instruction block(即{})最多可嵌套15层。

8.宏可嵌套8层。

9.最多可向宏或函数传递32个参数。

10.一行或一个宏最多只能有2000个字符,即使在宏扩展后也不能超过2000字符。

点评

请问上面1、4、9这三条这是什么C语言编译器的限制? 我写的金水151编译器除了XDATA变量空间不足,就没有这样的限制。  详情 回复 发表于 2024-9-27 13:08
DebugLab
回复 支持 1 反对 0

使用道具 举报 送花

  • 打卡等级:偶尔看看I
  • 打卡总天数:16
  • 最近打卡:2025-04-30 08:41:32

105

主题

1215

回帖

1万

积分

荣誉版主

积分
12882
发表于 2024-9-27 13:08:26 | 显示全部楼层
Debu*** 发表于 2024-9-27 10:46
1.对任何标准类型数据的访问,其间接访问级数最大为19级。这包括数组下标,间接操作符等

2.名称长度最长不 ...

请问上面1、4、9这三条这是什么C语言编译器的限制?
我写的金水151编译器除了XDATA变量空间不足,就没有这样的限制。

点评

keil,网上查的  详情 回复 发表于 2024-9-27 14:11
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:425
  • 最近打卡:2025-05-03 00:09:43
已绑定手机

77

主题

4850

回帖

8388

积分

超级版主

DebugLab

积分
8388
发表于 2024-9-27 14:11:40 | 显示全部楼层
杨*** 发表于 2024-9-27 13:08
请问上面1、4、9这三条这是什么C语言编译器的限制?
我写的金水151编译器除了XDATA变量空间不足,就没有 ...

keil,网上查的

点评

(1)好的,有空我落实一下。 (2)1、4限制本质上是限制了递归调用的层数。这是不应该的。 (3)数学的很多问题都需要递归方法解决。因此C语言教科书上从未提及要限制递归层数,通常的编译器提到递归限制只是指出递  详情 回复 发表于 2024-9-27 20:43
DebugLab
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:常住居民III
  • 打卡总天数:138
  • 最近打卡:2025-05-01 23:08:49
已绑定手机

54

主题

39

回帖

832

积分

高级会员

积分
832
发表于 2024-9-27 20:28:37 | 显示全部楼层
包含文件最多可嵌套9层。
中招了,就这个问题!
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:常住居民III
  • 打卡总天数:138
  • 最近打卡:2025-05-01 23:08:49
已绑定手机

54

主题

39

回帖

832

积分

高级会员

积分
832
发表于 2024-9-27 20:30:13 | 显示全部楼层
4.函数参数列表中的函数的嵌套调用层数最多为10层。

5.包含文件最多可嵌套9层。

有没有一个推荐的好的解决方案?
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:偶尔看看I
  • 打卡总天数:16
  • 最近打卡:2025-04-30 08:41:32

105

主题

1215

回帖

1万

积分

荣誉版主

积分
12882
发表于 2024-9-27 20:43:59 | 显示全部楼层

(1)好的,有空我落实一下。
(2)1、4限制本质上是限制了递归调用的层数。这是不应该的。
(3)数学的很多问题都需要递归方法解决。因此C语言教科书上从未提及要限制递归层数,通常的编译器提到递归限制只是指出递归层数太多会耗尽RAM空间,造成系统崩溃。
(4)C51/C251编译器采用了函数树来跟踪函数调用情况,也许是这个功能产生的限制,所以要落实。金水151编译器没有这个功能,所以也就没有这种限制
回复 支持 反对

使用道具 举报 送花

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

本版积分规则

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

GMT+8, 2025-5-3 03:24 , Processed in 0.117620 second(s), 92 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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