以独立方式从 C 调用C++
Calling C++ from C in a freestanding way
我有一个用C++编写的内核尝试,我想把它移植到UEFI x86_64,但是使用GNU-efi库的EFI引导加载程序必须用C编写。
如何从 C 跳转到主内核函数?一直使用extern C
使得无法使用C++特性,也许可以使用一些汇编代码,或者我可以让引导加载程序调用一个 ELF 文件,该文件将成为带有 ELF 加载器的主内核。这种解决方案是否可行?
一路使用
extern C
使C++特性的使用变得不可能
其实不然。在标头中编写extern "C"
并使用C++编译器编译函数并在单独的翻译单元中使用各种C++功能都没有问题。
您只需要避免C++名称重整即可C++实现入口函数。这就是extern "C"
的作用,如果你把它用于函数声明。
下面是一个小示例:
kernel.h
extern "C" void main_entry_point();
kernel.cpp
#include "kernel.h"
void main_entry_point() {
// use std::string, std::vector, etc.
}
bootloader.c
#include "kernel.h"
// call main_entry_point()
main_entry_point();
相关文章:
- 什么时候调用组成单元对象的析构函数
- 对RValue对象调用的LValue ref限定成员函数
- 为什么使用 "this" 指针调用派生成员函数?
- 函数调用中参数的顺序重要吗
- OpenGL - 在抛出"__gnu_cxx::recursive_init_error"实例后终止调用?
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 在c++类上调用void函数
- 为什么 std::unique 不调用 std::sort?
- 调用专用模板时出错"no matching function for call to [...]"
- 选择要调用的构造函数
- C++为什么尽管我调用了void函数,它却不起作用
- 构造函数正在调用一个使用当前类类型的函数
- 变量没有改变?通过向量的函数调用
- 没有为自己的结构调用列表推回方法
- 调用'begin(int [n])'没有匹配函数
- 什么时候调用析构函数
- 如何用参数值调用函数(仅在运行时已知)
- std::cout.imbue()多重调用
- 函数何时会在c++中包含stack_Unwind_Resume调用