- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我已经搜索过,但找不到明确的答案。如果我们在计算机(功能强大)中编译代码,那么我们只是将机器指令发送到嵌入式设备中的内存。根据我的理解,如果我们使用任何一种语言,这不会有什么不同,因为最终,我们将只向嵌入式设备发送机器代码,代码编译是昂贵的阶段,已经由强大的功能完成机器!
为什么要使用像 C 这样的语言?为什么不是Java?我们在最后发送机器码。
最佳答案
答案部分在于运行时要求和平台提供的语言期望:C 的运行时大小是最小的 - 它需要一个堆栈,这就是能够开始运行代码的地方。对于兼容的实现,静态数据初始化是必需的,但您可以在没有它的情况下运行代码 - 初始化本身甚至可以用 C 编写,甚至堆和标准库初始化都是可选的,就像库的存在一样。它不需要操作系统依赖性、解释器和虚拟机。
大多数其他语言需要更多的运行时支持,这通常由操作系统、运行时库或虚拟机提供。要“独立”运行,这些语言需要“内置”支持,因此会更大——以至于在许多情况下,您也可以部署带有操作系统和/或 JVM 的系统无论如何。
当然,特定语言适合嵌入式系统还有其他原因,例如硬件级访问、性能和确定性行为。
虽然运行时环境和/或操作系统的问题是您在小型嵌入式系统中很少看到高级语言的主要原因,但这绝不是闻所未闻的。 .Net Micro Framework例如允许在嵌入式系统中使用 C#,并且有许多 embedded JVM实现,当然还有 Linux 发行版被广泛嵌入,使得语言选择几乎不受限制。 .Net Micro 运行在有限数量的处理器架构上,需要相当大的内存(>256kb),JVM 实现可能有类似的要求。 Linux 不会在低于 16Mb ROM/4Mb RAM 的情况下启动。两者都不是特别适合具有微秒级截止日期的硬实时应用程序。
C 在 8 位、16 位、32 位和 64 位平台上或多或少地普遍存在,并且从第一天起通常可用于任何架构,而对其他语言(至少 32 位平台上的 C++ 除外)的支持可能是可变且不完整,并且可能仅在更成熟或广泛使用的平台上可用。
从开发人员的角度来看,一个重要的考虑因素也是针对目标平台和语言的交叉编译工具的可用性。因此,这是一个良性循环,开发人员选择 C(或越来越多地选择 C++),因为这是最广泛使用的工具,而工具/芯片供应商提供 C 和 C++ 工具链,因为这是开发人员的需求。再加上库、开源代码、调试器、RTOS 等形式的第三方支持,选择一种几乎没有任何支持的语言将是勇敢(或愚蠢)的开发人员。受此影响的不仅仅是高级语言。我曾经参与过一个用 Forth 编程的项目——一种比 C 更底层的语言——那是一次孤独的经历,虽然有这种语言的热情拥护者,但坦率地说,他们有点疯狂地偏爱语言传播而不是商业上的成功。简而言之,C 已达到临界质量接受度并且很难被移除。 C++ 受益于与 C 的广泛互操作性和类似的最低运行时要求,以及通常支持这两种语言的工具链。因此,采用 C++ 的唯一障碍主要是开发人员的惯性,以及在某种程度上在 8 位和 16 位平台上的可用性。
关于c - 为什么对嵌入式系统使用低级语言或接近它( C )而不是高级语言,当所有语言都被编译为机器代码时?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36245710/
对于相当简单的表结构,即。人员、标准和 PersonCriteria(组合表),我现在设置了一个查询,选择所有符合所有选定条件的人。 此时查询本身看起来像这样: SELECT p.PersonID
我在使用高级 SQL 查询时遇到了一些问题,而且我已经有很长时间没有使用 SQL 数据库了。我们使用 MySQL。 背景: 我们将使用两个表: “交易表” 表:expire_history +----
我找不到错误。也许你可以帮助我:我的代码如下: var data = {"product":[{"config":[{"id":"1","price":"100","sku":"1054879634
我有一个列表列表的列表(最后一个列表并不重要) data = [[[['f', 0], 'C'], [['X', 0], 'X']], [[['s', 1], 'X'], [['X', 0], 'X'
我想准备将使用表格的 session ,并在另一个网站上将新项目添加到 session 中。 默认.cs string[] tab = new string[100];
我知道有一些像: Bubble sort Insertion sort Shell sort Merge sort Heapsort Quicksort Bucket sort Radix sort
像https://softwareengineering.stackexchange.com/questions/150616/return-random-list-item-by-its-weigh
我正在开发一个 posix 脚本 (Linux),它获取一个网页,将内容存储在一个变量中并查找字符串“SUCCESS”。如果找到字符串,则不执行循环内容,如果没有找到字符串,则反复执行循环,直到找到为
我不确定这个问题是否已在其他地方得到解答,而且我似乎无法通过谷歌找到任何不是“Hello World”示例的内容...我正在使用 C# .NET 4.0 进行编码。 我正在尝试开发一个控制台应用程序,
我创建了一个房地产网站,我希望按照列表的最后更新和完整性对列表进行排序。所以我一直想弄清楚如何结合最近更新的列表按mysql中的字段(completion_score)进行排序。完成分数将采用 1
只所以称为“高级”用法,是因为我连switch的最基础的用法都还没有掌握,so,接下来讲的其实还是它的基础用法! switch 语句和具有同样表达式的一系列的 IF 语句相似。很多场合下需要把同一
之前的章节中,我们学习了 XML DOM,并使用了 XML DOM 的 getElementsByTagName() 方法从 XML 文档中取回数据 本章节我们将继续学习其它重要的 XML DOM
我对我尝试编写的 SQL 查询有疑问。 我需要从数据库中查询数据。该数据库除其他外,还包括以下 3 个字段: Account_ID #, Date_Created, Time_Created 我需要编
我正在使用非常激进的视频压缩,例如 -crf 51 .我将其用于“艺术”效果,因此从普通视频压缩的角度来看,我所做的可能没有意义。 到目前为止,我只使用了非常基本的压缩控制,只使用了 -crf。或 -
我真的在学习 lucene 和 ravendb 上的绳索 - 我在 Raven 中有以下文档 - { "InternalEvent": { "Desec": "MachineInfo: 1
通常 grep 命令用于显示包含指定模式的行。有没有办法在包含指定模式的行之前和之后显示 n 行? 这可以使用awk来实现吗? 最佳答案 是的,使用 grep -B num1 -A num2 在匹配之
我搜索了高低,并尝试了几个小时来操纵似乎适合的各种其他查询,但我没有快乐。 我试图加入 Microsoft SQL Server 2005 中的几个表,其中一个示例是: Company Table (
我有一个如下所示的 XML 文件: teacher1Name
我将如何在 CF 中创建此语句? 显然括号不起作用,但说明了我想要完成的工作。这是什么语法? 编辑: 好的,我了解如何使用 EQ 等等。我有点匆忙地发布了这个。我的问题是关于括号。以这种方式使用它们
主要问题:我需要使用具体对象结构对任何对象结构进行类型扩展。 我在 VS Code 中测试的默认值。 我的解决方案: /** @template A @typedef {{[Ki in keyof A
我是一名优秀的程序员,十分优秀!