ZHAOBAO511 发表于 2019-8-6 14:54:03

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

单片机 变量会变?变量中存好的值过一会就变了?不是单片机原因吧。

jyrpxj 发表于 2019-8-6 15:08:08

数组指针跑出

ZHAOBAO511 发表于 2019-8-6 15:19:04

jyrpxj 发表于 2019-8-6 15:08
数组指针跑出

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

t3486784401 发表于 2019-8-6 15:22:18

厂区有核辐射?

ZHAOBAO511 发表于 2019-8-6 15:29:01

t3486784401 发表于 2019-8-6 15:22
厂区有核辐射?

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

ordman 发表于 2019-8-6 15:29:31

stack设置太小,发生溢出了

fulitun 发表于 2019-8-6 15:32:59

jyrpxj 发表于 2019-8-6 15:08
数组指针跑出

+1               


lzchuo 发表于 2019-8-6 15:52:11

把指针全部屏蔽,估计就好了

ZHAOBAO511 发表于 2019-8-6 15:53:21

ordman 发表于 2019-8-6 15:29
stack设置太小,发生溢出了

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

ZHAOBAO511 发表于 2019-8-6 15:53:47

lzchuo 发表于 2019-8-6 15:52
把指针全部屏蔽,估计就好了

我再看看,谢谢。

ZHAOBAO511 发表于 2019-8-6 15:54:10

fulitun 发表于 2019-8-6 15:32
+1

不一定是,当时是好的。

polarbear 发表于 2019-8-6 15:54:28

没有可能是单片机对应的那个字节的RAM 的三极管有缺陷, 可能是没有完全导通,处于放大状态

huangyiting1990 发表于 2019-8-6 15:56:47

ZHAOBAO511 发表于 2019-8-6 15:54
不一定是,当时是好的。

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

ZHAOBAO511 发表于 2019-8-6 15:57:54

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

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

ZHAOBAO511 发表于 2019-8-6 15:58:15

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

是吧,我再找找看。

jiege0119 发表于 2019-8-6 16:04:22

查看MAP文件,仔细看这变量附近的指针

ZHAOBAO511 发表于 2019-8-6 16:05:40

jiege0119 发表于 2019-8-6 16:04
查看MAP文件,仔细看这变量附近的指针

好的,谢谢,我看看。

mcu5i51 发表于 2019-8-6 17:58:37

如果有全面的调试,就下个变量写入断点吧,多数是溢出

yeahmen 发表于 2019-8-6 18:02:32

有些 bug 是不是作用域或运算符优先级造成的问题 {:lol:}

whatcanitbe 发表于 2019-8-6 18:06:15

多处操作,还有中断

ZHAOBAO511 发表于 2019-8-6 18:12:01

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

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

ZHAOBAO511 发表于 2019-8-6 18:12:21

yeahmen 发表于 2019-8-6 18:02
有些 bug 是不是作用域或运算符优先级造成的问题

再加几个扩号试试。

arm 发表于 2019-8-6 18:20:54

堆栈溢出了吧

ZHAOBAO511 发表于 2019-8-6 18:36:10

whatcanitbe 发表于 2019-8-6 18:06
多处操作,还有中断

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

ZHAOBAO511 发表于 2019-8-6 18:43:43

arm 发表于 2019-8-6 18:20
堆栈溢出了吧

不是,浮点数。

laujc 发表于 2019-8-6 18:48:56

51单片机不知道,我用renesas的单片机,使用dataflash库时会这样,后来才发现,data flash库占用了一部分变量的地址。。。

ZHAOBAO511 发表于 2019-8-6 18:59:13

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

加个变量,等于这个就可以了。{:lol:}

lxa0 发表于 2019-8-6 19:20:29

怕是硬件的问题。
建议换AT的单片机。

n0831 发表于 2019-8-6 19:32:03

感觉是人的问题,建议换人。

snkaka 发表于 2019-8-6 19:32:49

其他地方数组溢出导致的

ZHAOBAO511 发表于 2019-8-6 19:33:00

lxa0 发表于 2019-8-6 19:20
怕是硬件的问题。
建议换AT的单片机。

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

ZHAOBAO511 发表于 2019-8-6 19:35:52

snkaka 发表于 2019-8-6 19:32
其他地方数组溢出导致的

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

cht-rtos 发表于 2019-8-6 20:06:55

成长的必由之路,仿真数据断点走起

ZHAOBAO511 发表于 2019-8-6 20:20:51

cht-rtos 发表于 2019-8-6 20:06
成长的必由之路,仿真数据断点走起

没仿真器,直接写程序烧,仿真器太贵了。{:lol:}

HZKJ 发表于 2019-8-7 00:13:45

不会变还叫变量吗

snkaka 发表于 2019-8-7 00:23:47

ZHAOBAO511 发表于 2019-8-6 19:35
有可能,不过加个变量就好了。

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

master5888 发表于 2019-8-7 06:00:01

百分百是人的问题

icoyool 发表于 2019-8-7 07:17:30

99%是内存出问题了, 加一个内存断点看看, ,

wuha 发表于 2019-8-7 07:26:02

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

ZHAOBAO511 发表于 2019-8-7 07:45:49

HZKJ 发表于 2019-8-7 00:13
不会变还叫变量吗

{:lol:} 你牛啊,自己变的。

ZHAOBAO511 发表于 2019-8-7 07:46:30

snkaka 发表于 2019-8-7 00:23
你这样是治标不治本啊,必须别查到底

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

ZHAOBAO511 发表于 2019-8-7 07:46:54

master5888 发表于 2019-8-7 06:00
百分百是人的问题

没有仿真器。

ZHAOBAO511 发表于 2019-8-7 07:47:26

master5888 发表于 2019-8-7 06:00
百分百是人的问题

没有仿真器。

ZHAOBAO511 发表于 2019-8-7 07:47:43

icoyool 发表于 2019-8-7 07:17
99%是内存出问题了, 加一个内存断点看看, ,

断不了,没有仿真。

ZHAOBAO511 发表于 2019-8-7 07:48:22

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

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

ordman 发表于 2019-8-7 09:24:58

ZHAOBAO511 发表于 2019-8-7 07:48
应该是程序问题,不过没有仿真器,没法查。

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

zcs 发表于 2019-8-7 09:25:37

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

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

ZHAOBAO511 发表于 2019-8-7 09:26:46

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

500多个变量,相互交错的。{:lol:}

dadatou 发表于 2019-8-7 09:35:18

voltaile了解一下。

yunqing_abc 发表于 2019-8-7 09:47:15

dadatou 发表于 2019-8-7 09:35
voltaile了解一下。

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

leicai05 发表于 2019-8-7 09:50:07

重点看看数组赋值和指针赋值的地方吧,十有八九是数组下标溢出或者指针溢出造成的。

迅得电子 发表于 2019-8-7 09:52:11

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

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

ZHAOBAO511 发表于 2019-8-7 09:58:17

dadatou 发表于 2019-8-7 09:35
voltaile了解一下。

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

ZHAOBAO511 发表于 2019-8-7 09:59:27

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

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

ZHAOBAO511 发表于 2019-8-7 09:59:56

迅得电子 发表于 2019-8-7 09:52
这么太麻烦了,语句太多,工作量太大了

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

knight_sh 发表于 2019-8-7 10:03:05

1,内存溢出;2 volatile修饰变量

迅得电子 发表于 2019-8-7 10:07:34

ZHAOBAO511 发表于 2019-8-7 09:59
对,太多了,你中有我,我中有你,全屏蔽可能不工作了。

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

cocom 发表于 2019-8-7 10:11:50

可能是早餐吃得太少或吃了大蒜引起的异常。
引起这种问题的原因,99.999&是单片机内部软件的问题,也就是编写者的问题。

modbus 发表于 2019-8-7 10:17:06

ZHAOBAO511 发表于 2019-8-7 07:47
断不了,没有仿真。

有种断点叫while(1)

磊磊映画 发表于 2019-8-7 10:23:07

单步调试 应该是bug

ZHAOBAO511 发表于 2019-8-7 10:35:26

knight_sh 发表于 2019-8-7 10:03
1,内存溢出;2 volatile修饰变量

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

ZHAOBAO511 发表于 2019-8-7 10:35:58

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

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

ZHAOBAO511 发表于 2019-8-7 10:36:29

modbus 发表于 2019-8-7 10:17
有种断点叫while(1)

思路可以,后面试试。

ZHAOBAO511 发表于 2019-8-7 10:36:59

磊磊映画 发表于 2019-8-7 10:23
单步调试 应该是bug

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

knight_sh 发表于 2019-8-7 11:07:28

ZHAOBAO511 发表于 2019-8-7 09:26
500多个变量,相互交错的。

这个工程是个灾难

ZHAOBAO511 发表于 2019-8-7 11:09:40

knight_sh 发表于 2019-8-7 11:07
这个工程是个灾难

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

shjw 发表于 2019-8-7 11:23:53

搭车问个问题:
编译时候选择PRO,运行某语句会改变不相关变量(称X);把这行语句注释了,变量X就不会改变了。
编译设置为LITE,程序运行正常。

磊磊映画 发表于 2019-8-7 13:59:11

ZHAOBAO511 发表于 2019-8-7 10:36
没有仿真器,不可以单步。

串口打印行吗

ZHAOBAO511 发表于 2019-8-7 14:21:40

磊磊映画 发表于 2019-8-7 13:59
串口打印行吗

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

磊磊映画 发表于 2019-8-7 14:32:34

ZHAOBAO511 发表于 2019-8-7 14:21
本来就是个测试仪,串口发送的,程序很复杂

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

ZHAOBAO511 发表于 2019-8-7 14:54:29

磊磊映画 发表于 2019-8-7 14:32
在线调试 串口打印 两种很好的手段都不用   找bug 效率挺低的

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

Jach 发表于 2019-8-7 16:08:19

ZHAOBAO511 发表于 2019-8-7 07:46
谢谢!主要是没有仿真器,仿真器很贵。看不到变量变化。

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

bujie8010 发表于 2019-8-7 17:01:48

多年前有过同样的问题,折腾了半个月,后来发现自己手欠在另外一个地方加了段中断测试程序,忘了关掉了。仅供参考!

laujc 发表于 2019-8-7 17:27:51

zcs 发表于 2019-8-7 09:25
可否详谈是哪些地址被占用了,正在用瑞萨的瑟瑟发抖。

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

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

laujc 发表于 2019-8-7 17:33:49

zcs 发表于 2019-8-7 09:25
可否详谈是哪些地址被占用了,正在用瑞萨的瑟瑟发抖。

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

eaglelpx 发表于 2019-8-7 17:35:41

数组问题可能性很大

磊磊映画 发表于 2019-8-7 17:40:02

ZHAOBAO511 发表于 2019-8-7 14:54
已经在用了,但要每个变量都输出有些困难,这一个变量肯定有输出了。

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

xpstudio2011 发表于 2019-8-7 17:56:40

把这个变量一直串口输出,或者读取检测,看一下是什么 情况下发生的改变。

ZHAOBAO511 发表于 2019-8-7 19:07:56

Jach 发表于 2019-8-7 16:08
很好奇, 沒有除錯工具, 你怎麼確定是"變量"變了?

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

ZHAOBAO511 发表于 2019-8-7 19:08:27

xpstudio2011 发表于 2019-8-7 17:56
把这个变量一直串口输出,或者读取检测,看一下是什么 情况下发生的改变。 ...

开中断的时候。

ZHAOBAO511 发表于 2019-8-7 19:08:55

磊磊映画 发表于 2019-8-7 17:40
嗯 别着急慢慢来,相信很快你会解决掉这个问题的

谢谢,应该会解决的。

ZHAOBAO511 发表于 2019-8-7 19:09:28

磊磊映画 发表于 2019-8-7 17:40
嗯 别着急慢慢来,相信很快你会解决掉这个问题的

谢谢,应该会解决的。

ZHAOBAO511 发表于 2019-8-7 19:10:19

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

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

ZHAOBAO511 发表于 2019-8-7 19:10:42

eaglelpx 发表于 2019-8-7 17:35
数组问题可能性很大

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

szjqt 发表于 2019-8-7 20:05:58

这很常见,千万别轻易怀疑片子,根据多年经验,都是代码的问题。

formatme 发表于 2019-8-7 20:17:45

只要不是新片子,一般都是代码问题,+1.

ZHAOBAO511 发表于 2019-8-8 08:35:31

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

应该是代码问题。

ZHAOBAO511 发表于 2019-8-8 09:20:23

结贴了,朋友们,原来是这样的:我用中断采集数据,中断的数据只能向外传可以,外面的数据向中断内传不行,根本不认,我把算法挪到WHILE中就可以啦!
页: [1]
查看完整版本: 单片机 变量会变?变量中存好的值过一会就变了?