keil 错误时自动提示求极值时如果被处理的数为有符号数,程序应该如何改动

君,已阅读到文档的结尾了呢~~
⑴ 了解WORD功能,掌握WORD的基本操作,包括页眉/页脚的设置、分栏、页面设置、
添加底纹 ..... 掌握穷举算法、迭代算法、递推算法等一些常用算法的程序设计方法。
扫扫二维码,随身浏览文档
手机或平板扫扫即可继续访问
举报该文档为侵权文档。
举报该文档含有违规或不良信息。
反馈该文档无法正常浏览。
举报该文档为重复文档。
推荐理由:
将文档分享至:
分享完整地址
文档地址:
粘贴到BBS或博客
flash地址:
支持嵌入FLASH地址的网站使用
html代码:
&embed src='/DocinViewer-4.swf' width='100%' height='600' type=application/x-shockwave-flash ALLOWFULLSCREEN='true' ALLOWSCRIPTACCESS='always'&&/embed&
450px*300px480px*400px650px*490px
支持嵌入HTML代码的网站使用
您的内容已经提交成功
您所提交的内容需要审核后才能发布,请您等待!
3秒自动关闭窗口12-10;由于某原因收方不对主机寻址信号应答时,例如接收方;数据时,必须释放总线,将数据线置为高电平,而由主;当主机接收来自从机的数据时,接收到最后一个数据字;依次调用依照上述数据传送格式的12.5.2小节中;第13章AT89S51单片机的应用设计与调试参考;1.答:A.错;B.错;C.对;D.错(最小系统;2.答:用户样机是以AT89S51单片机为核心的
12-10。I2C总线在传送每一字节数据后都须有应答信号A,A信号在第9个时钟位上出现,A信号对应的时钟由主机产生。这时发方须在该时钟位上使SDA线处于高电平,以便收方在这一位上送出低电平的应答信号A。 由于某原因收方不对主机寻址信号应答时,例如接收方正在进行其他处理而无法接收总线上的数据时,必须释放总线,将数据线置为高电平,而由主机产生一个终止信
号以结束总线的数据传送。 当主机接收来自从机的数据时,接收到最后一个数据字节后,必须给从机发送一个非应答信号( ),使从机释放数据总线,以便主机发送一个终止信号,从而结束数据的传送。 6.答:依照下面的数据传送格式: S 从机地址 0 A 数据 A/
Sr 从机地址r 1 A 数据
P 依次调用依照上述数据传送格式的12.5.2小节中的各子程序。
AT89S51单片机的应用设计与调试 参考答案 1.答:A.错;B.错;C.对;D.错(最小系统不能直接测量模拟信号)。 2.答:用户样机是以AT89S51单片机为核心的应用系统,没有对单片机中的程序进行检错调试的手段,也无法发现程序运行中的设计硬件的问题,也无法进行软件的开发(如编辑、汇编、调试程序等),因此,必须借助某种开发工具---仿真开发系统所提供的开发手段来解决上述问题。 3.答:仿真开发系统由哪几部分组成? 目前国内大多使用通用机的仿真开发系统。主要由PC机、在线仿真器组成,有的还包含有用于程序烧录的编程器,在加上与上述配套的编辑软件、仿真调试软件,程序烧录软件等。 此外还有独立型仿真器。该类仿真器采用模块化结构,配有不同外设,如外存板、打印机、键盘/显示器等,用户可根据需要选用。尤其在工业现场进行程序仿真调试时,往往没有PC机的支持,这时使用独立型仿真器也可进行仿真调试工作,只不过要输入机器码,稍显麻烦一些。 至于软件仿真开发工具Proteus软件是一种完全用软件手段对单片机应用系统进行仿真开发的。软件仿真开发工具与用户样机在硬件上无任何联系。不能进行用户样机硬件部分的诊断与实时在线仿真。 4.答:调试过程见图13-13,4个步骤。 (1)输入用户源程序:用户使用编辑软件源程序输入到PC机中,并保存在磁盘上。 (2)汇编并检查语法错误:在PC机上,利用汇编程序对用户源程序进行汇编,直至语法错误全部纠正为止。 (3)动态在线调试:对用户的源程序进行调试。要先把在线仿真器的仿真插头插入用户样机的单片机插座中(图13-12),进行在线仿真调试,利用仿真开发系统提供单步、设置断点等调试手段,来进行系统的调试。纠正软件逻辑上的问题,或排除硬件上的故障。 (4)将调试完毕的用户程序通过程序烧写器,固化在程序存储器中。 5.答:由于软件仿真开发工具Proteus软件是一种完全用软件手段对单片机应用系统进行仿真开发的。不能进行用户样机硬件部分的诊断与实时在线仿真。因此在系统的开发中,一般是先用Proteus仿真软件设计出系统的硬件电路,编写程序,然后在Proteus环
境下仿真调试通过。然后依照仿真的结果,完成实际的硬件设计。再将仿真通过的程序烧录到编程器中,然后安装到用户样机硬件板上去观察运行结果,如果有问题,再连接硬件仿真器去分析、调试。 6.答:在每块印刷电路板的电源输入端跨接的电容应为一个10~100μF的大容量电解电容(如体积允许,电容量大一些更好)和一个0.01~0.1μF的非电解电容。用于去除干扰中的高频干扰和低频干扰,并接大电容为了去掉低频干扰成分,并接小电容为了去掉高频干扰部分。 7.答:光电耦合的主要优点是能有效抑制尖峰脉冲以及各种噪声干扰,从而使过程通道上的信噪比大大提高。因为在工业现场的数据采集或实时控制中,过程通道的输入输出信号线和控制线多,且长度达几百米或几千米,因此不可避免地将干扰引入单片机系统。消除或减弱过程通道的干扰主要采用光电隔离技术。所谓光电隔离采用光电耦合器可以将单片机与前向、后向以及其他部分切断电路的联系,能有效地防止干扰从过程通道进入单片机(见图13-14)。 8.答:对于单片机应用系统中的具有较大电感量的元件或设备,诸如继电器、电动机、电磁阀等。当电感回路的电流被切断时,会产生很大的反电势而形成噪声干扰。这种反电势甚至可能击穿电路中晶体管之类的器件,反电势形成的噪声干扰能产生电磁场,对单片机应用系统中的其它电路产生干扰。如果通过电感线圈的是直流电流,可采用如下措施加以抑制: (1)可在线圈两端并联二极管和稳压管,如图 (a) 所示。
图 (a)由二极管和稳压管构成的反电势抑制电路
图(b) 由电阻和二级管组成的反电势抑制电路。 在稳定工作时,并联支路被二极管D阻断而不起作用;当三极管T由通道变为截止时,在电感线圈两端产生反电势e。此电势可在并联支路中流通,因此e的幅值被限制在稳压管DZ的工作电压范围之内,并被很快消耗掉,从而抑制了反电势的干扰。使用时DZ的工作电压应选择得比外加电源高些。 如果把稳压管换为电阻,同样可以达到抑制反电势的目的,如图(b)所示,因此也适用于直流驱动线圈的电路。在这个电路中,电阻的阻值范围可以从几欧姆到几十欧姆。阻值太小,反电势衰减得慢;而阻值太大又会增大反电势的幅值。 (2)反电势抑制电路也可由电阻和电容组成,如图(c)所示。适当选择R、C
由电阻和电容组成的抑制电路 参数,也能获得较好的耗能效果。这种电路不仅适用于交流驱动的线圈,也适用于直流驱动的线圈。 (3)反电势抑制电路不但可以接在线圈的两端,也可以接在开关的两端,
例如继电器,接触器等部件在操作时,开关会产生较大的火花,必须利用RC电路加以吸收,如图(d),一般R取1~2KΩ,C取2.2~4.7μF。
接在开关的两端的反电势抑制电路 9.答:数字地通常有很大的噪声而且电平的跳跃会造成很大的电流尖峰,对模拟地有较大的影响,会引起模拟电路产生误差。所以正确的接法是,必须将所有的模拟地和数字地分别相连,然后模拟(公共)地与数字(公共)地仅在一点上相连接,且地线应尽量加粗,如图13-17。 在ADC和DAC电路中,尤其要注意地线的正确连接,否则会引起ADC和DAC转换结果的不准确。由于ADC、DAC芯片都提供了相应独立的模拟地和数字地引脚,一定要把模拟地引脚和数字地引脚尽可能短的相连。然后再与模拟地尽可能短的连接。 10.答: (1)电源去耦 已经在第6题中介绍,就是在印刷电路板的电源输入端跨接退耦电容。跨接的电容应为一个10~100μF的大容量电解电容(如体积允许,电容量大一些更好)和一个0.01~0.1μF的非电解电容。 (2)集成芯片去耦 每个集成芯片都应安置一个0.01μF的瓷片去耦电容,去耦电容必须安装在本集成芯片的Vcc和GND线之间,否则便失去了抗干扰作用。 如遇到印刷电路板空隙小装不下时,可每4~10个芯片安置一个1~10μF高频阻抗特别小的钽电容器。对于抗噪声能力弱,关断电流大的器件和ROM、RAM存储器,应在芯片的电源线Vcc和地线(GND)间接入去耦的瓷片电容。 11.答:(1)在印制板中留下无用的空白铜箔层,可充当发射天线或接收天线,可把就近它们接地。(2)走线不要有分支,可避免在线路条在传输高频信号导致反射干扰或发生谐波干扰。 12.答:常见的软件滤波方法有(1)算术平均滤波法:一般适用于具有随机干扰的信号的滤波。(2)滑动平均滤波法:对周期性干扰有良好的抑制作用,平滑度高,灵敏度低;但对偶然出现的脉冲性干扰的抑制作用差。(3)中位值滤波法:能有效地克服因偶然因素引起的波动干扰。对温度、液位等变化缓慢的被测参数能收到良好的滤波效果。但对流量、速度等快速变化的参数一般不宜采用此法。(4)去极值平均值滤波法:算术平均与滑动平均滤波法,在脉冲干扰比较严重的场合,干扰将会“平均”到结果中去,故上述两种平均值法不易消除由于脉冲干扰而引起的误差,这时可采用去极值平均值滤波法。去极值平均值滤波法类似于体育比赛中的去掉最高、最低分,再求平均。 13.答:(1)指令冗余:当单片机系统受干扰时,PC中由于干扰发生错误,会产生“乱飞”。当乱飞到某双字节指令,若取指令时刻
落在操作数上,误将操作数当作操作码,程序有可能出错。若乱飞到三字节指令,出错概率更大,这时可在双字节指令和三字节指令后插入两个字节以上的NOP指令,可保护其后的指令不被拆散,这称为指令冗余。(2)软件陷阱:就是一条引导指令“LJMP
ERP”,强行将乱飞的程序引向一个指定的地址入口标号“ERP”,在那里有一段专门对程序出错进行处理的程序。为加强其捕捉效果,一般还在它前面加两条NOP指令。 14.答:无论是AT89S51单片机片内集成的 “看门狗”还是专门的硬件“看门狗”电路,原理都是使用一个计数器来不断计数,监视程序的运行。当计数器启动运行后,为防止计数器的不必要溢出,应定期性地把WDT计数器清0,以保证其不溢出。当单片机的程序“跑飞”或陷入“死循环”时,也就不能定时地把看门狗计数器清0。当看门狗计数器值计满溢出时,将在AT89S51的RST引脚上输出一个正脉冲使AT89S51单片机复位,在系统的复位入口0000H处安排一条跳向出错处理程序段的指令或重新从头执行程序,从而使程序摆脱 “跑飞”或“死循环”状态。 15.答:当系统掉电或供电电压过低时,有时需要保护RAM中的重要内容,这时可使用微处理器监控器芯片中的“掉电保护”功能,即给单片机接上备用电池,微处理器监控器芯片会在掉电时自动为单片机系统提供电源,从而保护了RAM中的重要内容。
单片机C语言程序设计基础 参考答案 1.答:C51在标准C的基础上,作了以下扩充: (1)数据类型的不同。51系列单片机包含位操作空间和丰富的位操作指令,因此Keil C51与ANSI C相比又扩展了4种类型,以便能够灵活地进行操作。 (2)头文件。生产51系列单片机的厂家有多个,它们的差异在于内部资源如定时器、中断、I/O等数量以及功能的不同,而对于使用者来说,只需要将相应的功能寄存器的头文件加载在程序内,就可实现它们所具有的功能。因此,Keil C51系列的头文件集中体现了各系列芯片的不同资源及功能。 (3)数据存储类型的不同。标准C最初是为通用计算机设计的,在通用计算机中只有一个程序和数据统一寻址的内存空间,而51系列单片机有片内、外程序存储器,还有片内、外数据存储器。标准C并没有提供这部分存储器的地址范围的定义。此外,对于AT89C51单片机中大量的特殊功能寄存器也没有定义。 (4)标准C没有处理单片机中断的定义。 (5)库函数有较大不同。标准C的库函数中有一些库函数可继续使用部分库函数不适合于嵌入式处理器系统,因此它们被排除在Keil C51之外,例如库函数printf和scanf,在标准C中,这两个
函数通常用于屏幕打印和接收字符,而在Keil C51中,它们主要用于串行口数据的收发。 (6)51单片机的硬件资源有限,C51的编译系统不允许太多的程序嵌套。其次,标准C所具备的递归特性不被Keil C51支持。 但是从数据运算操作、程序控制语句以及函数的使用上来说,Keil C51与标准C几乎没有什么明显的差别。如果程序设计者具备了有关标准C的编程基础,只要注意Keil C51与标准C的不同之处,并熟悉AT89S51单片机的硬件结构,就能够较快地使用Keil C51编程。 2. 答:略。 3. 答:略。 4. 答:略。 5. 答:可参考例14-8,将波形数据输出从零开始不断增1到达最大值后不断减1,回零后再不断增1到达最大值后不断减1,从而重复不断发出三角波波形的数据。
三亿文库包含各类专业文献、文学作品欣赏、高等教育、各类资格考试、应用写作文书、中学教育、单片机原理及应用第二版课后习题答案[1]171等内容。 
 第一章习题 1.什么是单片机?单片机和通用微机相比有何特点? 答:单片机又称为单片微计算机,它的结构特点是将微型计算机的基 本功能部件(如中央处理器(CPU) 、...  单片机原理及应用课后习题参考答案1~6章_工学_高等教育_教育专区。单片机原理及应用课后习题参考答案1~6章《单片机原理及应用》习题答案 第一章 计算机基础知识 1-...  单片机原理及应用第二版课后习题答案[1]1 隐藏&& 第1 章 单片机概述参考答案 1.1 答:微控制器,嵌入式控制器 1.2 答:CPU、存储器、I/O 口、总线 1.3 ...  单片机原理及应用第二版张毅刚 课后习题答案_工学_高等教育_教育专区。第1章参考答案 1.答:微控制器,嵌入式控制器 2.答:CPU、存储器、I/O 口、总线 3.答:...  单片机原理与应用课后习题答案_工学_高等教育_教育专区。习题 0 1.单片机是把组成...(2)第二阶段( 年) :在单片芯片内集成 CPU、并行口、定时器/计...  单片机原理及应用课后习题答案__张兰红_工学_高等教育_教育专区。 文库分享网 单片机原理及应用 张兰红 9 第 1 章 微型计算机的基本概念 ...  单片机原理及应用(第二版)课后答案_工学_高等教育_教育专区。作业答案 0-1 ...(1#) :4000H~5FFFH 6264(2#) :6000H~7FFFH 图 4.18 4.18 题硬件...  《单片机原理及应用》习题参考答案 第一章 1. 为什么计算机要采用二进制数?学习十六进制数的目的是什么? 在计算机中,由于所采用的电子逻辑器件仅能存储和识别两种...对不起,您要访问的页面暂时没有找到,您可以:查看: 3654|回复: 36
keil中,一个全局变量经常被清零,有什么好的办法查出原因
在keil中,我有一个全局变量,经常会被清零,目前的线索如下:
1.我主动进行清零的地方,整个程序中只有一处,在调试模式下,我在该处设置了断点,发生清零事件是时,从未运行到此处断点。
2.程序中用到过指针,也用到过结构体,考虑到了可能是指针越界,通过map文件,找到了这个变量的内存分配地址中的前一个变量,
 一起加入到调试监视的watch1中,发生清零事件是时,前一个变量并没有变化。
3.如果改变一下这个变量声明的位置,比如从后部移到前部,则程序一切正常。
这种问题,不找出来,是很怕的,有什么诊断的好办法呢?谢谢
M3的单片机,性能还是蛮强大的~
要是论坛要评十大某某代码,我为此投一票...
别的地方数组有溢出没有,我遇到过
被这串参数吓到了
这样传递参数,看的就纠结
年末见识到了函数和单片机的强大
今年年末见识到了函数和单片机的强大
加写断点,这种断点是硬断点
楼主,对你这写的程序无语了
肯定是越界或者溢出了
已解决,不过只知道和一个自编的求极值函数有关,还是和数据类型的定义有关
之前出问题是是这样调用的:I_re ...
楼主新手吗?&&传参数,一般最多3个,像你这种 直接做一个结构体,传入指针就好了。
像你这样效率很低的。
16个浮点变量直接传递,而不用指针,也是醉了。
这个函数,一直没做满意,本来想做一个包括8\16\32位,实数的比较的,变量声明不好处理,就变成这样了
16个浮点变量直接传递,而不用指针,也是醉了。
这是51 这种IC的典型症状&&因为资源不够用,你得紧着用。
我这个不是51,应该是cortex-m3的,NXP1768
这是51 这种IC的典型症状&&因为资源不够用,你得紧着用。
已解决,不过只知道和一个自编的求极值函数有关,还是和数据类型的定义有关
之前出问题是是这样调用的:I_result=GetMinMaxNum( 1,i1,i2,i3,i4,0,0,0,0,0,0,0,0,0,0,0,0);
修改OK后是这样的:I_result=(uint32_t )GetMinMaxNum( 1,(float)i1,(float)i2,(float)i3,(float)i4,0,0,0,0,0,0,0,0,0,0,0,0);
//从16个数浮点数中找出极大值,极小值
//Imode:&&1 求极大值  0 求极小值
// f0-f15,数据输入;
float GetMinMaxNum(char iMode,float f0,float f1,float f2,float f3,float f4,float f5,float f6,float f7,float f8,float f9,float f10,float f11,float f12,float f13,float f14,float f15)
& & & & float ftmp[16];
& & & & char i1,I
& & & & ftmp[0]=f0;& & & & ftmp[1]=f1;& & & & ftmp[2]=f2;& & & & & & & & ftmp[3]=f3;& & & & & & & & ftmp[4]=f4;& & & & & & & & ftmp[5]=f5;& & & & & & & & ftmp[6]=f6;& & & & & & & & ftmp[7]=f7;
& & & & ftmp[8]=f8;& & & & ftmp[9]=f9;& & & & ftmp[10]=f10;& & & & ftmp[11]=f11;& & & & ftmp[12]=f12;& & & & ftmp[13]=f13;& & & & ftmp[14]=f14;& & & & ftmp[15]=f15;
& & & & Iindex=0;
& & & & for ( i1=0;i1!=16;++i1)
&&if (iMode && (ftmp[Iindex ] & ftmp[i1]))
& &Iindex=i1;& & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & //单语句时可以省略花括号
&&else if (!iMode && (ftmp[Iindex] & ftmp[i1]))
& &Iindex=i1;& & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & //单语句时可以省略花括号
return ftmp[Iindex ];
7楼正解,数据条件断点。全局变量被意外修改,一般是数组或指针访问越界。也有可能栈空间太小,编译器分配的局部变量地址和全局变量地址重叠!
加写断点,这种断点是硬断点
使用硬断点
昨天我还碰到类似的问题。就是数组越界,影响了别的变量。楼主好好查查
堆栈溢出、数组、指针溢出等等。
本帖最后由 sunjun 于
11:36 编辑
是不是有的函数有很多局部变量,是的话,把局部变量前全部加上static,如果问题解决,那么就是堆栈的问题
我在使用C的时候,也遇到过类似的问题,程序烧录到芯片后,大部分芯片是好用的,执行正确. 但是有10%左右的芯片,总有某些变量莫名其妙的被修改.
有哪位碰到这种情况吗?
1,是不是在数组后面定义,数组溢出,覆盖了。
2,降低优化等级。
3,加volatile
再提供一个思路,是否有复杂的调用路径?甚至动态的函数指针?
尤其是动态函数指针,编译器遇到这种情况没法完 ...
上次遇到這問題就想到應該是這原因,
看了一下 .map ,看此變數 address 前的變數是哪個,
結果就抓到了。
keil不是可以设置条件中断的吗
再提供一个思路,是否有复杂的调用路径?甚至动态的函数指针?
尤其是动态函数指针,编译器遇到这种情况没法完全的分析其调用路径,有可能会造成局部变量物理地址复用过程中覆盖了其他变量.
另外MDK的话,可以用编译器命令强行把这个变量指定在某个地址,debug起来就对着这个地址盯着~
调试器里面可以用命令行的方式下访问断点,hit到这个地址就暂停CPU,不过印象中需要调试器支持,Jlink肯定可以的.
几点需要注意:
1: 堆栈空间扩大试试;
2:结构体变量定义时考虑处理器的字宽度
3:检查指针赋值;
一般是数组越界或者野指针等引起。
多半都是内存溢出造成的,再仔细看看。
数据断点,数据变为0时触发断点
1.缓冲区溢出,
2,堆栈增长覆盖全局变量区域了,这种概率比较大。
数组 指针 。。。越界 可能
重点查数组的数据溢出。
是不是溢出了?有一次我的RAM多了一个字节,也不报警,在调用固定的子函数时全局变量有时会被清零,子函数有几个局部变量,去掉两个就没事了!
加写断点,这种断点是硬断点
友情提示:标题不合格、重复发帖,将会被封锁ID。详情请参考:
您需要登录后才可以回帖
阿莫电子论坛, 原"中国电子开发网"

我要回帖

更多关于 keilc51和mdk同时安装 的文章

 

随机推荐