单片机 变量会变?变量中存好的值过一会就变了?
单片机 变量会变?变量中存好的值过一会就变了?不是单片机原因吧。 数组指针跑出 jyrpxj 发表于 2019-8-6 15:08数组指针跑出
不是数组,就是一普通变量,多次调用,出错。 厂区有核辐射? t3486784401 发表于 2019-8-6 15:22
厂区有核辐射?
没有,其他好好的,就这一两个老是不 一样。 stack设置太小,发生溢出了 jyrpxj 发表于 2019-8-6 15:08
数组指针跑出
+1
把指针全部屏蔽,估计就好了 ordman 发表于 2019-8-6 15:29
stack设置太小,发生溢出了
没溢出,当时存是好的,过会才变。 lzchuo 发表于 2019-8-6 15:52
把指针全部屏蔽,估计就好了
我再看看,谢谢。 fulitun 发表于 2019-8-6 15:32
+1
不一定是,当时是好的。 没有可能是单片机对应的那个字节的RAM 的三极管有缺陷, 可能是没有完全导通,处于放大状态 ZHAOBAO511 发表于 2019-8-6 15:54
不一定是,当时是好的。
非常大概率指针溢出 。 并不是说你这个变量是指针溢出了 , 而是运行起来后,别的地方指针溢出了,刚好赶上改掉了这个变量的值{:lol:} polarbear 发表于 2019-8-6 15:54
没有可能是单片机对应的那个字节的RAM 的三极管有缺陷, 可能是没有完全导通,处于放大状态 ...
这个应该没可能,因为这种片子测试很严的 huangyiting1990 发表于 2019-8-6 15:56
非常大概率指针溢出 。 并不是说你这个变量是指针溢出了 , 而是运行起来后,别的地方指针溢出了 ...
是吧,我再找找看。 查看MAP文件,仔细看这变量附近的指针 jiege0119 发表于 2019-8-6 16:04
查看MAP文件,仔细看这变量附近的指针
好的,谢谢,我看看。 如果有全面的调试,就下个变量写入断点吧,多数是溢出 有些 bug 是不是作用域或运算符优先级造成的问题 {:lol:} 多处操作,还有中断 mcu5i51 发表于 2019-8-6 17:58
如果有全面的调试,就下个变量写入断点吧,多数是溢出
没溢出,应该是中断改写。 yeahmen 发表于 2019-8-6 18:02
有些 bug 是不是作用域或运算符优先级造成的问题
再加几个扩号试试。 堆栈溢出了吧 whatcanitbe 发表于 2019-8-6 18:06
多处操作,还有中断
就是中断这里,我按键改写了值,中断中用这个值去计算。 arm 发表于 2019-8-6 18:20
堆栈溢出了吧
不是,浮点数。 51单片机不知道,我用renesas的单片机,使用dataflash库时会这样,后来才发现,data flash库占用了一部分变量的地址。。。
laujc 发表于 2019-8-6 18:48
51单片机不知道,我用renesas的单片机,使用dataflash库时会这样,后来才发现,data flash库占用了一部分变 ...
加个变量,等于这个就可以了。{:lol:} 怕是硬件的问题。
建议换AT的单片机。 感觉是人的问题,建议换人。 其他地方数组溢出导致的 lxa0 发表于 2019-8-6 19:20
怕是硬件的问题。
建议换AT的单片机。
不是硬件问题。比AT的贵的多。100元的51 snkaka 发表于 2019-8-6 19:32
其他地方数组溢出导致的
有可能,不过加个变量就好了。 成长的必由之路,仿真数据断点走起 cht-rtos 发表于 2019-8-6 20:06
成长的必由之路,仿真数据断点走起
没仿真器,直接写程序烧,仿真器太贵了。{:lol:} 不会变还叫变量吗 ZHAOBAO511 发表于 2019-8-6 19:35
有可能,不过加个变量就好了。
你这样是治标不治本啊,必须别查到底 百分百是人的问题 99%是内存出问题了, 加一个内存断点看看, , 无数亲身经历证明,当怀疑单片机本身问题时,查到最后还是写的程序的问题,虽然当时非常怪异和难以想象。
变量无端变化,不是数组越界,就是个别指针被程序异常改变,栈溢出一般很少见,除非单片机RAM很少,且函数嵌套很深,或者发生递归调用。 HZKJ 发表于 2019-8-7 00:13
不会变还叫变量吗
{:lol:} 你牛啊,自己变的。 snkaka 发表于 2019-8-7 00:23
你这样是治标不治本啊,必须别查到底
谢谢!主要是没有仿真器,仿真器很贵。看不到变量变化。 master5888 发表于 2019-8-7 06:00
百分百是人的问题
没有仿真器。 master5888 发表于 2019-8-7 06:00
百分百是人的问题
没有仿真器。 icoyool 发表于 2019-8-7 07:17
99%是内存出问题了, 加一个内存断点看看, ,
断不了,没有仿真。 wuha 发表于 2019-8-7 07:26
无数亲身经历证明,当怀疑单片机本身问题时,查到最后还是写的程序的问题,虽然当时非常怪异和难以想象。
...
应该是程序问题,不过没有仿真器,没法查。 ZHAOBAO511 发表于 2019-8-7 07:48
应该是程序问题,不过没有仿真器,没法查。
当然有办法排查!
一个个函数注释,甚至最后保留到只有一个while循环。就可以一个个排查,不断缩小范围。 laujc 发表于 2019-8-6 18:48
51单片机不知道,我用renesas的单片机,使用dataflash库时会这样,后来才发现,data flash库占用了一部分变 ...
可否详谈是哪些地址被占用了,正在用瑞萨的瑟瑟发抖。 ordman 发表于 2019-8-7 09:24
当然有办法排查!
一个个函数注释,甚至最后保留到只有一个while循环。就可以一个个排查,不断缩小范围。 ...
500多个变量,相互交错的。{:lol:} voltaile了解一下。 dadatou 发表于 2019-8-7 09:35
voltaile了解一下。
我程序中的全局变量都是volatile的
重点看看数组赋值和指针赋值的地方吧,十有八九是数组下标溢出或者指针溢出造成的。 ordman 发表于 2019-8-7 09:24
当然有办法排查!
一个个函数注释,甚至最后保留到只有一个while循环。就可以一个个排查,不断缩小范围。 ...
这么太麻烦了,语句太多,工作量太大了 dadatou 发表于 2019-8-7 09:35
voltaile了解一下。
没用,以前试过,刚试了一下,不行。 leicai05 发表于 2019-8-7 09:50
重点看看数组赋值和指针赋值的地方吧,十有八九是数组下标溢出或者指针溢出造成的。 ...
是吧,有时间看看,项目是有期限的。 迅得电子 发表于 2019-8-7 09:52
这么太麻烦了,语句太多,工作量太大了
对,太多了,你中有我,我中有你,全屏蔽可能不工作了。 1,内存溢出;2 volatile修饰变量 ZHAOBAO511 发表于 2019-8-7 09:59
对,太多了,你中有我,我中有你,全屏蔽可能不工作了。
不可取,这样排查,人都搞乏了 可能是早餐吃得太少或吃了大蒜引起的异常。
引起这种问题的原因,99.999&是单片机内部软件的问题,也就是编写者的问题。 ZHAOBAO511 发表于 2019-8-7 07:47
断不了,没有仿真。
有种断点叫while(1) 单步调试 应该是bug knight_sh 发表于 2019-8-7 10:03
1,内存溢出;2 volatile修饰变量
定义数的时候都很注意的,都在计算范围内的,修饰变量无用。 cocom 发表于 2019-8-7 10:11
可能是早餐吃得太少或吃了大蒜引起的异常。
引起这种问题的原因,99.999&是单片机内部软件的问题,也就是编 ...
程序多了出问题很正常,都30K了,不可能一点小问题都没。 modbus 发表于 2019-8-7 10:17
有种断点叫while(1)
思路可以,后面试试。 磊磊映画 发表于 2019-8-7 10:23
单步调试 应该是bug
没有仿真器,不可以单步。 ZHAOBAO511 发表于 2019-8-7 09:26
500多个变量,相互交错的。
这个工程是个灾难 knight_sh 发表于 2019-8-7 11:07
这个工程是个灾难
{:lol:} 变量和存储本来就是大量用的,越复杂产品越交错。 搭车问个问题:
编译时候选择PRO,运行某语句会改变不相关变量(称X);把这行语句注释了,变量X就不会改变了。
编译设置为LITE,程序运行正常。 ZHAOBAO511 发表于 2019-8-7 10:36
没有仿真器,不可以单步。
串口打印行吗 磊磊映画 发表于 2019-8-7 13:59
串口打印行吗
本来就是个测试仪,串口发送的,程序很复杂 ZHAOBAO511 发表于 2019-8-7 14:21
本来就是个测试仪,串口发送的,程序很复杂
在线调试 串口打印 两种很好的手段都不用 找bug 效率挺低的 磊磊映画 发表于 2019-8-7 14:32
在线调试 串口打印 两种很好的手段都不用 找bug 效率挺低的
已经在用了,但要每个变量都输出有些困难,这一个变量肯定有输出了。 ZHAOBAO511 发表于 2019-8-7 07:46
谢谢!主要是没有仿真器,仿真器很贵。看不到变量变化。
很好奇, 沒有除錯工具, 你怎麼確定是"變量"變了? 多年前有过同样的问题,折腾了半个月,后来发现自己手欠在另外一个地方加了段中断测试程序,忘了关掉了。仅供参考! zcs 发表于 2019-8-7 09:25
可否详谈是哪些地址被占用了,正在用瑞萨的瑟瑟发抖。
保存data Flash时,data flash库函数会强制指定RAM区的一片区域
所以需要修改.dr文件,跳开那片区域
zcs 发表于 2019-8-7 09:25
可否详谈是哪些地址被占用了,正在用瑞萨的瑟瑟发抖。
详细可以看官方R01US0049EJ0105 文档
这个如果不知道的情况下,确实是个坑。
数组问题可能性很大 ZHAOBAO511 发表于 2019-8-7 14:54
已经在用了,但要每个变量都输出有些困难,这一个变量肯定有输出了。
嗯 别着急慢慢来,相信很快你会解决掉这个问题的 把这个变量一直串口输出,或者读取检测,看一下是什么 情况下发生的改变。 Jach 发表于 2019-8-7 16:08
很好奇, 沒有除錯工具, 你怎麼確定是"變量"變了?
我给变量了一个值,这个值是定值,结果一开中断就变了。 xpstudio2011 发表于 2019-8-7 17:56
把这个变量一直串口输出,或者读取检测,看一下是什么 情况下发生的改变。 ...
开中断的时候。 磊磊映画 发表于 2019-8-7 17:40
嗯 别着急慢慢来,相信很快你会解决掉这个问题的
谢谢,应该会解决的。
磊磊映画 发表于 2019-8-7 17:40
嗯 别着急慢慢来,相信很快你会解决掉这个问题的
谢谢,应该会解决的。 bujie8010 发表于 2019-8-7 17:01
多年前有过同样的问题,折腾了半个月,后来发现自己手欠在另外一个地方加了段中断测试程序,忘了关掉了。仅 ...
我的是正常的中断开有这个现象的。 eaglelpx 发表于 2019-8-7 17:35
数组问题可能性很大
应该不是,开中断时变化的。 这很常见,千万别轻易怀疑片子,根据多年经验,都是代码的问题。 只要不是新片子,一般都是代码问题,+1. szjqt 发表于 2019-8-7 20:05
这很常见,千万别轻易怀疑片子,根据多年经验,都是代码的问题。
应该是代码问题。 结贴了,朋友们,原来是这样的:我用中断采集数据,中断的数据只能向外传可以,外面的数据向中断内传不行,根本不认,我把算法挪到WHILE中就可以啦!
页:
[1]