Gen*_*ene 2 c c++ embedded misra autosar
我正在启动一个新的 C/C++ 嵌入式应用程序,并试图让自己了解诸如 MISRA、AUTOSAR 和我目前最喜欢的安全编码实践,这可能是因为它是最短的,NASA 所谓的 10 次幂(https://en.wikipedia) .org/wiki/The_Power_of_10:_Rules_for_Developing_Safety-Critical_Code)。我可以看到许多规则背后的逻辑。但他们都试图消除或限制动态内存分配。例如,MISRA C++ 规则 18-4-1 说:“不应使用动态堆内存分配”,而 NASA 的规则 3 是“避免堆内存分配”。AUTOSAR 的限制较少。我理解他们的意图是确保系统不会耗尽内存,但我不太清楚 C 或 C++ 编译器将什么分配为“动态堆内存分配”或“堆内存分配”。我将编辑这篇文章以提出具体问题
谢谢 - 基因
MISRA 规则的核心是动态内存分配问题
malloc()导致使用空指针的返回状态。malloc(),其中充斥着未定义、未指定和实现定义的行为,这使得编译器和实现之间具有可移植性,因此行为具有一定程度的不可预测性。MISRA C/C++ 的一些派生类(例如 JSF、NASA JPL、AUTOSAR)允许malloc()在初始化阶段(但不允许realloc()等或后续free())使用,这消除了所有碎片问题 - 但不解决不完整的定义。
当然,定制解决方案可能是完全可以证明的,在这种情况下,MISRA 规则的偏差是可以的。
但总的来说,使用动态内存的弊端超过了任何潜在的好处。
免责声明:是的,我与 MISRA 有关联……查看个人资料
| 归档时间: |
|
| 查看次数: |
295 次 |
| 最近记录: |