OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3758|回复: 4

stm8s+stvd,一个全局变量类型产生的奇怪问题。

[复制链接]

1

主题

4

帖子

0

精华

新手上路

积分
48
金钱
48
注册时间
2019-7-7
在线时间
15 小时
发表于 2019-8-30 14:19:35 | 显示全部楼层 |阅读模式
5金钱
一个全局变量,当定义为unsigned char时程序正常,但是定义为unsigned short时程序就有问题。

例如以下一段简单的代码:

if(a<50)
{
    a++;
}
else
{
    a=0
}

当a为unsigned char时一切正常,但是为unsigned short型时就有问题,比如自加到十几或者其它多少就莫名的自动变成零。
总之很奇怪的问题,程序没有逻辑和语法错误。

我怀疑编译器需要怎样设置?有谁有类似的经验吗?

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165352
金钱
165352
注册时间
2010-12-1
在线时间
2108 小时
发表于 2019-8-31 02:17:57 | 显示全部楼层
回复

使用道具 举报

1

主题

4

帖子

0

精华

新手上路

积分
48
金钱
48
注册时间
2019-7-7
在线时间
15 小时
 楼主| 发表于 2019-9-2 16:25:45 | 显示全部楼层

感谢原子兄帮顶,最近有点忙没怎么有时间去检查是什么问题,等有空点再去研究一下看看是什么问题或者自己哪里弄错了,到时再来向大家请教或分享。
这个问题先结了。
回复

使用道具 举报

21

主题

131

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
423
金钱
423
注册时间
2019-5-12
在线时间
168 小时
发表于 2019-9-5 14:40:39 | 显示全部楼层
我的猜测是编译器自动做了优化,您可以试着在类型前加一个volatile,这个是防止编译器自动做优化
回复

使用道具 举报

0

主题

70

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
206
金钱
206
注册时间
2019-12-3
在线时间
27 小时
发表于 2019-12-5 17:41:58 | 显示全部楼层
编译的时候打开 list 文件输出,然后在list文件中看编译器生成的汇编指令.很快就会找到问题的.
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-25 03:48

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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