重入函数(51单片机常见问题)

2025-05-03 16:26:31 函数指令 嘉兴
  1. 什么是可重入函数
  2. 51单片机常见问题
  3. 中断函数使用原则

什么是可重入函数

可重入函数:主要用于多任务环境中,一个可重入函数简单来说就是可以被中断的函数,也就是说,可以在这个函数执行的任何时刻中断它,转入OS调度下去执行另外一段代码,而返回控制时不会出现什么错误。

51单片机常见问题

) 操作系统软件的代码不能太长

重入函数(51单片机常见问题)

  因为51系列单片机的系统硬件资源相对匮乏,如果操作系统的代码比应用程序的代码还大,甚至使得用户的应用程序要考虑给操作系统让出资源,这样的操作系统即使功能再完善,也不实用。现在流行的嵌入式操作系统就不能应用于51系列单片机,原因是代码太大。开发一个5000行的基于裸机的应用程序也就是占用7~8KB ROM空间,一个操作系统用掉了几十KB,占空间不算,实时性的优势恐怕也没了(执行这么多的指令要时间)。所以,μCOS的作者也不支持将他的代码移植到51系列单片机上,这也就不奇怪了。

(2) 操作系统不能占用太多的片内RAM空间

  51系列单片机只有128个或者256个字节的片内RAM空间,稍微不注意就用完了。如果操作系统把片内的RAM使用得所剩无几,那用户的应用程序用什么? 如果说用户的程序可以把变量定义在片外RAM中的话,那么系统的硬件堆栈放在哪? 众所周知,51系列单片机的硬件堆栈不能放在片外,所以要在51系列单片机上开发操作系统的话就要少用它的片内RAM。但是不用片内RAM是办不到的,因为操作系统也要传递参数,也要使用堆栈。C51单片机的C函数传递参数是通过寄存器和存储器的,不能通过堆栈。但是可以通过一些措施使得操作系统代码少用片内RAM。

(3) 解决好函数的重入问题

重入函数(51单片机常见问题)

中断函数使用原则

1. 中断处理函数的返回值和形参

中断处理函数不能有返回值和形参,因为中断处理函数都是硬件调用(或者叫触发),没有程序给它传递参数,也没有程序接收它的返回值,其参数的传递通过全局变量的方式。

但是要注意,如果在中断服务函数中改变了供其他函数检测的全局变量的值,要使用volatile关键字定义该全局变量。因为主程序可能将该变量读取到寄存器中,以后每次只使用寄存器中的变量副本,这时候吐过不使用volatile关键字,会导致中断服务函数中修改该变量的操作被短路

2. 中断处理函数中进行浮点数运算

重入函数(51单片机常见问题)

由于浮点运算一般都是由专门的硬件来完成的,硬件设备会牵扯到一些类似全局变量的东西(比如硬件端口,或者硬件设备本身存放的数据),如果浮点运算的过程被中断,而其他函数也可能使用浮点数运算,这就会破坏当前硬件设备中的数据。可以理解为浮点运算一般是不可重入的,因此不能在中断服务函数中使用浮点运算。

可以在满足精度的前提下,将浮点运算扩大若干倍,变成整型运算。

3. 中断处理函数中使用printf函数

这个原理跟上面的在中断服务函数中使用浮点数类似,因为printf函数使用硬件资源,而这些资源本身就应该互斥访问(在多线程和多进程中),而这些导致printf函数不可重入,不能在中断中使用。

另外像malloc,free这些函数会使用全局的内存分配表,因此也是不可重入的,不能在中断中使用。

到此,以上就是小编对于不可重入函数的问题就介绍到这了,希望介绍的3点解答对大家有用,有任何问题和不懂的,欢迎各位老师在评论区讨论,给我留言。

随机图文
    此处不必修改,程序自动调用!
  • 随机文章

  • 热门文章

  • 热评文章

vfp函数(vfp函数名缺少)
2025-04-18  阅读(18)
  • 乘以的函数(乘以的函数是什么)
    2025-04-18  阅读(43)
  • 函数e是什么意思,e的函数图像
    2025-04-19  阅读(52)
  • 三角函数角度对照表怎么背,各角度三角函数对照表图
    2025-04-20  阅读(102)
  • 在sql select语句(谁告诉我Linux简单常用命令以及SQL语句select from where的用法、SQL语句用汉语把意思表达清楚在举例)
    2025-04-20  阅读(19)
  • 奇函数导数是偶函数(偶函数的导数是奇还是偶)
    2025-04-20  阅读(17)
  • 怎样才能学好函数(怎么学好函数与基本初等函数)
    2025-04-20  阅读(30)
  • 阶跃函数的傅立叶变换(阶跃函数的傅立叶变换怎么求)
    2025-04-20  阅读(53)
  • sql语句自动生成(sql语句自动生成器)
    2025-05-04  阅读(537)
  • B函数求解(函数b的求法)
    2025-05-02  阅读(452)
  • 周期函数,周函数的使用方法
    2025-05-03  阅读(575)
  • 用第三个表达式替换第一个字符串表达式中出现的所有第二个给定字符串表达式。

    语法

    REPLACE ( ''string_replace1'' , ''string_replace2'' , ''string_replace3'' )

    参数

    SqlServer中REPLACE函数的使用,sql替换字符串函数

    ''string_replace1''

    待搜索的字符串表达式。string_replace1 可以是字符数据或二进制数据。

    ''string_replace2''

    待查找的字符串表达式。string_replace2 可以是字符数据或二进制数据。

    SqlServer中REPLACE函数的使用,sql替换字符串函数

    在SQL Server中,REPLACE函数用于替换字符串中出现的指定子字符串。它接受三个参数:原字符串,要被替换的子字符串和替换后的子字符串。

    该函数会查找原字符串中的所有匹配项,并将其替换为指定的字符串。如果原字符串中不存在要替换的子字符串,则不会发生任何更改。使用REPLACE函数可以轻松地进行字符串替换操作,例如将某些特定字符替换为其他字符或将一部分文本替换为其他文本。这在数据清洗和字符串处理中非常有用。

    sourceinsight怎么替换字符串

    12。replace('string" class="zf_thumb" width="48" height="48" title="SqlServer中REPLACE函数的使用,sql替换字符串函数" />

  • SqlServer中REPLACE函数的使用,sql替换字符串函数
    2025-05-03  阅读(525)
  • 一个已知的函数有几个原函数,任意原函数之间的差值是
    2025-05-02  阅读(444)
  • sql server新建表(sql如何新建数据库)
    2025-05-03  阅读(453)
  • 数行函数(数行数的函数)
    2025-05-03  阅读(454)
  • mysql数据库,指定到某一时间,它就自动执行相应的操作?sql语句该怎么写,定时执行sql语句设置
    2025-05-04  阅读(555)
  • 最新留言