搜索
bottom↓
回复: 87

单片机 变量会变?变量中存好的值过一会就变了?

[复制链接]

出75入8汤圆

发表于 2019-8-6 14:54:03 | 显示全部楼层 |阅读模式
单片机 变量会变?变量中存好的值过一会就变了?不是单片机原因吧。

阿莫论坛20周年了!感谢大家的支持与爱护!!

月入3000的是反美的。收入3万是亲美的。收入30万是移民美国的。收入300万是取得绿卡后回国,教唆那些3000来反美的!

出0入213汤圆

发表于 2019-8-6 15:08:08 来自手机 | 显示全部楼层
数组指针跑出

出75入8汤圆

 楼主| 发表于 2019-8-6 15:19:04 | 显示全部楼层

不是数组,就是一普通变量,多次调用,出错。

出200入2554汤圆

发表于 2019-8-6 15:22:18 | 显示全部楼层
厂区有核辐射?

出75入8汤圆

 楼主| 发表于 2019-8-6 15:29:01 | 显示全部楼层

没有,其他好好的,就这一两个老是不 一样。

出10入0汤圆

发表于 2019-8-6 15:29:31 来自手机 | 显示全部楼层
stack设置太小,发生溢出了

出0入4汤圆

发表于 2019-8-6 15:32:59 | 显示全部楼层

+1               


出0入0汤圆

发表于 2019-8-6 15:52:11 | 显示全部楼层
把指针全部屏蔽,估计就好了

出75入8汤圆

 楼主| 发表于 2019-8-6 15:53:21 | 显示全部楼层
ordman 发表于 2019-8-6 15:29
stack设置太小,发生溢出了

没溢出,当时存是好的,过会才变。

出75入8汤圆

 楼主| 发表于 2019-8-6 15:53:47 | 显示全部楼层
lzchuo 发表于 2019-8-6 15:52
把指针全部屏蔽,估计就好了

我再看看,谢谢。

出75入8汤圆

 楼主| 发表于 2019-8-6 15:54:10 | 显示全部楼层

不一定是,当时是好的。

出0入59汤圆

发表于 2019-8-6 15:54:28 | 显示全部楼层
没有可能是单片机对应的那个字节的RAM 的三极管有缺陷, 可能是没有完全导通,处于放大状态

出0入0汤圆

发表于 2019-8-6 15:56:47 | 显示全部楼层
ZHAOBAO511 发表于 2019-8-6 15:54
不一定是,当时是好的。

非常大概率  指针溢出 。       并不是说你这个变量是指针溢出了 , 而是运行起来后,别的地方指针溢出了,刚好赶上改掉了这个变量的值

出75入8汤圆

 楼主| 发表于 2019-8-6 15:57:54 | 显示全部楼层
polarbear 发表于 2019-8-6 15:54
没有可能是单片机对应的那个字节的RAM 的三极管有缺陷, 可能是没有完全导通,处于放大状态 ...

这个应该没可能,因为这种片子测试很严的

出75入8汤圆

 楼主| 发表于 2019-8-6 15:58:15 | 显示全部楼层
huangyiting1990 发表于 2019-8-6 15:56
非常大概率  指针溢出 。       并不是说你这个变量是指针溢出了 , 而是运行起来后,别的地方指针溢出了 ...

是吧,我再找找看。

出0入0汤圆

发表于 2019-8-6 16:04:22 | 显示全部楼层
查看MAP文件,仔细看这变量附近的指针

出75入8汤圆

 楼主| 发表于 2019-8-6 16:05:40 | 显示全部楼层
jiege0119 发表于 2019-8-6 16:04
查看MAP文件,仔细看这变量附近的指针

好的,谢谢,我看看。

出0入0汤圆

发表于 2019-8-6 17:58:37 | 显示全部楼层
如果有全面的调试,就下个变量写入断点吧,多数是溢出

出0入0汤圆

发表于 2019-8-6 18:02:32 | 显示全部楼层
有些 bug 是不是作用域或运算符优先级造成的问题

出100入85汤圆

发表于 2019-8-6 18:06:15 来自手机 | 显示全部楼层
多处操作,还有中断

出75入8汤圆

 楼主| 发表于 2019-8-6 18:12:01 | 显示全部楼层
mcu5i51 发表于 2019-8-6 17:58
如果有全面的调试,就下个变量写入断点吧,多数是溢出

没溢出,应该是中断改写。

出75入8汤圆

 楼主| 发表于 2019-8-6 18:12:21 | 显示全部楼层
yeahmen 发表于 2019-8-6 18:02
有些 bug 是不是作用域或运算符优先级造成的问题

再加几个扩号试试。

出0入0汤圆

发表于 2019-8-6 18:20:54 | 显示全部楼层
堆栈溢出了吧

出75入8汤圆

 楼主| 发表于 2019-8-6 18:36:10 | 显示全部楼层
whatcanitbe 发表于 2019-8-6 18:06
多处操作,还有中断

就是中断这里,我按键改写了值,中断中用这个值去计算。

出75入8汤圆

 楼主| 发表于 2019-8-6 18:43:43 | 显示全部楼层
arm 发表于 2019-8-6 18:20
堆栈溢出了吧

不是,浮点数。

出0入4汤圆

发表于 2019-8-6 18:48:56 | 显示全部楼层
51单片机不知道,我用renesas的单片机,使用dataflash库时会这样,后来才发现,data flash库占用了一部分变量的地址。。。

出75入8汤圆

 楼主| 发表于 2019-8-6 18:59:13 | 显示全部楼层
laujc 发表于 2019-8-6 18:48
51单片机不知道,我用renesas的单片机,使用dataflash库时会这样,后来才发现,data flash库占用了一部分变 ...

加个变量,等于这个就可以了。

出0入0汤圆

发表于 2019-8-6 19:20:29 | 显示全部楼层
怕是硬件的问题。
建议换AT的单片机。

出0入42汤圆

发表于 2019-8-6 19:32:03 来自手机 | 显示全部楼层
感觉是人的问题,建议换人。

出0入4汤圆

发表于 2019-8-6 19:32:49 来自手机 | 显示全部楼层
其他地方数组溢出导致的

出75入8汤圆

 楼主| 发表于 2019-8-6 19:33:00 | 显示全部楼层
lxa0 发表于 2019-8-6 19:20
怕是硬件的问题。
建议换AT的单片机。

不是硬件问题。比AT的贵的多。100元的51

出75入8汤圆

 楼主| 发表于 2019-8-6 19:35:52 | 显示全部楼层
snkaka 发表于 2019-8-6 19:32
其他地方数组溢出导致的

有可能,不过加个变量就好了。

出0入0汤圆

发表于 2019-8-6 20:06:55 来自手机 | 显示全部楼层
成长的必由之路,仿真数据断点走起

出75入8汤圆

 楼主| 发表于 2019-8-6 20:20:51 | 显示全部楼层
cht-rtos 发表于 2019-8-6 20:06
成长的必由之路,仿真数据断点走起

没仿真器,直接写程序烧,仿真器太贵了。

出0入17汤圆

发表于 2019-8-7 00:13:45 来自手机 | 显示全部楼层
不会变还叫变量吗

出0入4汤圆

发表于 2019-8-7 00:23:47 来自手机 | 显示全部楼层
ZHAOBAO511 发表于 2019-8-6 19:35
有可能,不过加个变量就好了。

你这样是治标不治本啊,必须别查到底

出0入0汤圆

发表于 2019-8-7 06:00:01 来自手机 | 显示全部楼层
百分百是人的问题

出0入8汤圆

发表于 2019-8-7 07:17:30 | 显示全部楼层
99%是内存出问题了, 加一个内存断点看看, ,

出0入0汤圆

发表于 2019-8-7 07:26:02 | 显示全部楼层
无数亲身经历证明,当怀疑单片机本身问题时,查到最后还是写的程序的问题,虽然当时非常怪异和难以想象。
变量无端变化,不是数组越界,就是个别指针被程序异常改变,栈溢出一般很少见,除非单片机RAM很少,且函数嵌套很深,或者发生递归调用。

出75入8汤圆

 楼主| 发表于 2019-8-7 07:45:49 | 显示全部楼层
HZKJ 发表于 2019-8-7 00:13
不会变还叫变量吗

你牛啊,自己变的。

出75入8汤圆

 楼主| 发表于 2019-8-7 07:46:30 | 显示全部楼层
snkaka 发表于 2019-8-7 00:23
你这样是治标不治本啊,必须别查到底

谢谢!主要是没有仿真器,仿真器很贵。看不到变量变化。

出75入8汤圆

 楼主| 发表于 2019-8-7 07:46:54 | 显示全部楼层
master5888 发表于 2019-8-7 06:00
百分百是人的问题

没有仿真器。

出75入8汤圆

 楼主| 发表于 2019-8-7 07:47:26 | 显示全部楼层
master5888 发表于 2019-8-7 06:00
百分百是人的问题

没有仿真器。

出75入8汤圆

 楼主| 发表于 2019-8-7 07:47:43 | 显示全部楼层
icoyool 发表于 2019-8-7 07:17
99%是内存出问题了, 加一个内存断点看看, ,

断不了,没有仿真。

出75入8汤圆

 楼主| 发表于 2019-8-7 07:48:22 | 显示全部楼层
wuha 发表于 2019-8-7 07:26
无数亲身经历证明,当怀疑单片机本身问题时,查到最后还是写的程序的问题,虽然当时非常怪异和难以想象。
...

应该是程序问题,不过没有仿真器,没法查。

出10入0汤圆

发表于 2019-8-7 09:24:58 | 显示全部楼层
ZHAOBAO511 发表于 2019-8-7 07:48
应该是程序问题,不过没有仿真器,没法查。

当然有办法排查!
一个个函数注释,甚至最后保留到只有一个while循环。就可以一个个排查,不断缩小范围。

出0入0汤圆

发表于 2019-8-7 09:25:37 | 显示全部楼层
laujc 发表于 2019-8-6 18:48
51单片机不知道,我用renesas的单片机,使用dataflash库时会这样,后来才发现,data flash库占用了一部分变 ...

可否详谈是哪些地址被占用了,正在用瑞萨的瑟瑟发抖。

出75入8汤圆

 楼主| 发表于 2019-8-7 09:26:46 | 显示全部楼层
ordman 发表于 2019-8-7 09:24
当然有办法排查!
一个个函数注释,甚至最后保留到只有一个while循环。就可以一个个排查,不断缩小范围。 ...

500多个变量,相互交错的。

出0入0汤圆

发表于 2019-8-7 09:35:18 来自手机 | 显示全部楼层
voltaile了解一下。

出0入4汤圆

发表于 2019-8-7 09:47:15 | 显示全部楼层
dadatou 发表于 2019-8-7 09:35
voltaile了解一下。


我程序中的全局变量都是volatile的

出0入0汤圆

发表于 2019-8-7 09:50:07 | 显示全部楼层
重点看看数组赋值和指针赋值的地方吧,十有八九是数组下标溢出或者指针溢出造成的。

出0入0汤圆

发表于 2019-8-7 09:52:11 | 显示全部楼层
ordman 发表于 2019-8-7 09:24
当然有办法排查!
一个个函数注释,甚至最后保留到只有一个while循环。就可以一个个排查,不断缩小范围。 ...

这么太麻烦了,语句太多,工作量太大了

出75入8汤圆

 楼主| 发表于 2019-8-7 09:58:17 | 显示全部楼层
dadatou 发表于 2019-8-7 09:35
voltaile了解一下。

没用,以前试过,刚试了一下,不行。

出75入8汤圆

 楼主| 发表于 2019-8-7 09:59:27 | 显示全部楼层
leicai05 发表于 2019-8-7 09:50
重点看看数组赋值和指针赋值的地方吧,十有八九是数组下标溢出或者指针溢出造成的。 ...

是吧,有时间看看,项目是有期限的。

出75入8汤圆

 楼主| 发表于 2019-8-7 09:59:56 | 显示全部楼层
迅得电子 发表于 2019-8-7 09:52
这么太麻烦了,语句太多,工作量太大了

对,太多了,你中有我,我中有你,全屏蔽可能不工作了。

出190入0汤圆

发表于 2019-8-7 10:03:05 | 显示全部楼层
1,内存溢出;2 volatile修饰变量

出0入0汤圆

发表于 2019-8-7 10:07:34 | 显示全部楼层
ZHAOBAO511 发表于 2019-8-7 09:59
对,太多了,你中有我,我中有你,全屏蔽可能不工作了。

不可取,这样排查,人都搞乏了

出0入42汤圆

发表于 2019-8-7 10:11:50 | 显示全部楼层
可能是早餐吃得太少或吃了大蒜引起的异常。
引起这种问题的原因,99.999&是单片机内部软件的问题,也就是编写者的问题。

出0入0汤圆

发表于 2019-8-7 10:17:06 | 显示全部楼层
ZHAOBAO511 发表于 2019-8-7 07:47
断不了,没有仿真。

有种断点叫while(1)

出0入0汤圆

发表于 2019-8-7 10:23:07 | 显示全部楼层
单步调试 应该是bug

出75入8汤圆

 楼主| 发表于 2019-8-7 10:35:26 | 显示全部楼层
knight_sh 发表于 2019-8-7 10:03
1,内存溢出;2 volatile修饰变量

定义数的时候都很注意的,都在计算范围内的,修饰变量无用。

出75入8汤圆

 楼主| 发表于 2019-8-7 10:35:58 | 显示全部楼层
cocom 发表于 2019-8-7 10:11
可能是早餐吃得太少或吃了大蒜引起的异常。
引起这种问题的原因,99.999&是单片机内部软件的问题,也就是编 ...

程序多了出问题很正常,都30K了,不可能一点小问题都没。

出75入8汤圆

 楼主| 发表于 2019-8-7 10:36:29 | 显示全部楼层
modbus 发表于 2019-8-7 10:17
有种断点叫while(1)

思路可以,后面试试。

出75入8汤圆

 楼主| 发表于 2019-8-7 10:36:59 | 显示全部楼层
磊磊映画 发表于 2019-8-7 10:23
单步调试 应该是bug

没有仿真器,不可以单步。

出190入0汤圆

发表于 2019-8-7 11:07:28 | 显示全部楼层
ZHAOBAO511 发表于 2019-8-7 09:26
500多个变量,相互交错的。

这个工程是个灾难

出75入8汤圆

 楼主| 发表于 2019-8-7 11:09:40 | 显示全部楼层
knight_sh 发表于 2019-8-7 11:07
这个工程是个灾难

变量和存储本来就是大量用的,越复杂产品越交错。

出0入0汤圆

发表于 2019-8-7 11:23:53 | 显示全部楼层
搭车问个问题:
编译时候选择PRO,运行某语句会改变不相关变量(称X);把这行语句注释了,变量X就不会改变了。
编译设置为LITE,程序运行正常。

出0入0汤圆

发表于 2019-8-7 13:59:11 | 显示全部楼层
ZHAOBAO511 发表于 2019-8-7 10:36
没有仿真器,不可以单步。

串口打印行吗

出75入8汤圆

 楼主| 发表于 2019-8-7 14:21:40 | 显示全部楼层

本来就是个测试仪,串口发送的,程序很复杂

出0入0汤圆

发表于 2019-8-7 14:32:34 | 显示全部楼层
ZHAOBAO511 发表于 2019-8-7 14:21
本来就是个测试仪,串口发送的,程序很复杂

在线调试 串口打印 两种很好的手段都不用   找bug 效率挺低的

出75入8汤圆

 楼主| 发表于 2019-8-7 14:54:29 | 显示全部楼层
磊磊映画 发表于 2019-8-7 14:32
在线调试 串口打印 两种很好的手段都不用   找bug 效率挺低的

已经在用了,但要每个变量都输出有些困难,这一个变量肯定有输出了。

出0入0汤圆

发表于 2019-8-7 16:08:19 | 显示全部楼层
ZHAOBAO511 发表于 2019-8-7 07:46
谢谢!主要是没有仿真器,仿真器很贵。看不到变量变化。

很好奇, 沒有除錯工具, 你怎麼確定是"變量"變了?

出0入8汤圆

发表于 2019-8-7 17:01:48 | 显示全部楼层
多年前有过同样的问题,折腾了半个月,后来发现自己手欠在另外一个地方加了段中断测试程序,忘了关掉了。仅供参考!

出0入4汤圆

发表于 2019-8-7 17:27:51 | 显示全部楼层
zcs 发表于 2019-8-7 09:25
可否详谈是哪些地址被占用了,正在用瑞萨的瑟瑟发抖。

保存data Flash时,data flash库函数会强制指定RAM区的一片区域

所以需要修改.dr文件,跳开那片区域

出0入4汤圆

发表于 2019-8-7 17:33:49 | 显示全部楼层
zcs 发表于 2019-8-7 09:25
可否详谈是哪些地址被占用了,正在用瑞萨的瑟瑟发抖。

详细可以看  官方R01US0049EJ0105 文档
这个如果不知道的情况下,确实是个坑。

出0入0汤圆

发表于 2019-8-7 17:35:41 | 显示全部楼层
数组问题可能性很大

出0入0汤圆

发表于 2019-8-7 17:40:02 | 显示全部楼层
ZHAOBAO511 发表于 2019-8-7 14:54
已经在用了,但要每个变量都输出有些困难,这一个变量肯定有输出了。

嗯 别着急慢慢来,相信很快你会解决掉这个问题的

出0入0汤圆

发表于 2019-8-7 17:56:40 | 显示全部楼层
把这个变量一直串口输出,或者读取检测,看一下是什么 情况下发生的改变。

出75入8汤圆

 楼主| 发表于 2019-8-7 19:07:56 | 显示全部楼层
Jach 发表于 2019-8-7 16:08
很好奇, 沒有除錯工具, 你怎麼確定是"變量"變了?

我给变量了一个值,这个值是定值,结果一开中断就变了。

出75入8汤圆

 楼主| 发表于 2019-8-7 19:08:27 | 显示全部楼层
xpstudio2011 发表于 2019-8-7 17:56
把这个变量一直串口输出,或者读取检测,看一下是什么 情况下发生的改变。 ...

开中断的时候。

出75入8汤圆

 楼主| 发表于 2019-8-7 19:08:55 | 显示全部楼层
磊磊映画 发表于 2019-8-7 17:40
嗯 别着急慢慢来,相信很快你会解决掉这个问题的

谢谢,应该会解决的。

出75入8汤圆

 楼主| 发表于 2019-8-7 19:09:28 | 显示全部楼层
磊磊映画 发表于 2019-8-7 17:40
嗯 别着急慢慢来,相信很快你会解决掉这个问题的

谢谢,应该会解决的。

出75入8汤圆

 楼主| 发表于 2019-8-7 19:10:19 | 显示全部楼层
bujie8010 发表于 2019-8-7 17:01
多年前有过同样的问题,折腾了半个月,后来发现自己手欠在另外一个地方加了段中断测试程序,忘了关掉了。仅 ...

我的是正常的中断开有这个现象的。

出75入8汤圆

 楼主| 发表于 2019-8-7 19:10:42 | 显示全部楼层
eaglelpx 发表于 2019-8-7 17:35
数组问题可能性很大

应该不是,开中断时变化的。

出0入89汤圆

发表于 2019-8-7 20:05:58 | 显示全部楼层
这很常见,千万别轻易怀疑片子,根据多年经验,都是代码的问题。

出0入0汤圆

发表于 2019-8-7 20:17:45 | 显示全部楼层
只要不是新片子,一般都是代码问题,+1.

出75入8汤圆

 楼主| 发表于 2019-8-8 08:35:31 | 显示全部楼层
szjqt 发表于 2019-8-7 20:05
这很常见,千万别轻易怀疑片子,根据多年经验,都是代码的问题。

应该是代码问题。

出75入8汤圆

 楼主| 发表于 2019-8-8 09:20:23 | 显示全部楼层
结贴了,朋友们,原来是这样的:我用中断采集数据,中断的数据只能向外传可以,外面的数据向中断内传不行,根本不认,我把算法挪到WHILE中就可以啦!
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-25 16:43

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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