Keil中报错:“explicit type is missing(“int“ assumed) _sys_exit(int x)”

2024-04-11 13:20

本文主要是介绍Keil中报错:“explicit type is missing(“int“ assumed) _sys_exit(int x)”,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题

Keil中编译时,出现error:explicit type is missing(“int” assumed) _sys_exit(int x),如图所示:
即:在 _sys_exit 函数的定义中,返回类型未显式声明,因此编译器默认假定它为 int 类型。这通常是因为在函数定义中未指定返回类型。
在这里插入图片描述

解决

很简单,指明函数返回的数据类型,并在函数定义中返回相应的数据类型即可。
如下两种方法都可以:
1,不返回任何值
在这里插入图片描述
2,返回一个整数
在这里插入图片描述

补充

1,这一行用于消除未使用参数的警告,是一种常见的处理方式。

x = x;

2,关于_sys_exit()

_sys_exit() 通常用于嵌入式系统或特定环境中,以替代标准库中的 exit() 函数,这主要用于避免链接标准库的某些部分,特别是与操作系统交互的部分。方法1的实现表示_sys_exit()被调用时不会执行任何操作,它只是一个空函数体,这在嵌入式系统中是合理的。

在嵌入式系统中,特别是在使用裸机编程(没有操作系统)的场景下,标准C库中的某些功能可能并不适用或者不必要。例如,标准C库中的 exit() 函数,它通常用于结束一个程序,并与操作系统进行一些交互,如关闭文件、释放资源等。但在嵌入式环境中,这样的操作可能并不适用,因为嵌入式程序通常是直接在硬件上运行,没有操作系统层的介入。

在这样的情况下,为了防止编译器引入不必要的标准库部分(这可能会增加程序的大小和复杂性),程序员可能会实现自己的 _sys_exit() 函数。在许多编译器中,如果没有定义 _sys_exit(),编译器可能会默认引入标准库的实现,这可能不适合嵌入式系统的要求。

通过定义一个空的 _sys_exit() 函数,实际上是在告诉编译器:“我知道标准库中有一个 exit() 函数,但在我的应用中,我不需要它做任何事情。” 这样,当程序中出现需要调用 exit() 的情况时(例如,当某些库函数内部尝试调用 exit()),它将调用空 _sys_exit() 函数,而不是标准库的版本。这样做的好处是避免了不必要的标准库代码引入,使得嵌入式应用更为精简和高效。

这篇关于Keil中报错:“explicit type is missing(“int“ assumed) _sys_exit(int x)”的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/894195

相关文章

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

MySQL报错sql_mode=only_full_group_by的问题解决

《MySQL报错sql_mode=only_full_group_by的问题解决》本文主要介绍了MySQL报错sql_mode=only_full_group_by的问题解决,文中通过示例代码介绍的非... 目录报错信息DataGrip 报错还原Navicat 报错还原报错原因解决方案查看当前 sql mo

oracle如何连接登陆SYS账号

《oracle如何连接登陆SYS账号》在Navicat12中连接Oracle11g的SYS用户时,如果设置了新密码但连接失败,可能是因为需要以SYSDBA或SYSOPER角色连接,解决方法是确保在连接... 目录oracle连接登陆NmOtMSYS账号工具问题解决SYS用户总结oracle连接登陆SYS账号

Oracle数据库如何切换登录用户(system和sys)

《Oracle数据库如何切换登录用户(system和sys)》文章介绍了如何使用SQL*Plus工具登录Oracle数据库的system用户,包括打开登录入口、输入用户名和口令、以及切换到sys用户的... 目录打开登录入口登录system用户总结打开登录入口win+R打开运行对话框,输php入:sqlp

解决Spring运行时报错:Consider defining a bean of type ‘xxx.xxx.xxx.Xxx‘ in your configuration

《解决Spring运行时报错:Considerdefiningabeanoftype‘xxx.xxx.xxx.Xxx‘inyourconfiguration》该文章主要讲述了在使用S... 目录问题分析解决方案总结问题Description:Parameter 0 of constructor in x

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

linux报错INFO:task xxxxxx:634 blocked for more than 120 seconds.三种解决方式

《linux报错INFO:taskxxxxxx:634blockedformorethan120seconds.三种解决方式》文章描述了一个Linux最小系统运行时出现的“hung_ta... 目录1.问题描述2.解决办法2.1 缩小文件系统缓存大小2.2 修改系统IO调度策略2.3 取消120秒时间限制3

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas