内核模式驱动不推荐使用C++的缘由

本文分析了为什么在内核模式驱动中不推荐使用C++,主要涉及内存页面交换的复杂性、堆分配问题、STL的局限性以及异常和RTTI的不可用性。C++的一些特性如构造函数、析构函数、虚函数等可能导致内核模式驱动的管理和调试困难。此外,STL的使用受限,异常处理和RTTI不适用于内核模式。建议使用C语言来编写内核模式驱动以保持代码的可控性和效率。
摘要由CSDN通过智能技术生成
本文所讲内容主要源自Windows DDK文档。

一、内存页面交换
和用户模式程序不同,内存页面交换对内核模式的代码不是透明的,而是需要一定程度的主动管理,要保证在代码执行过程中不会需要载入新的页面。编译器有相关的扩展#pragma指令来帮助C代码显式控制生成的二进制代码布局,以便相关的代码被放在一起,被调用时只需载入最少的页面。

而对C++而言,还存在一些编译器自动生成的代码块和数据,没有办法主动控制它们。比如编译器生成的缺省构造函数、析构函数、类型转换函数、赋值运算符重载;用于支持多重继承的adjustor thunk(没听说过?读 这个),用于实现虚函数调用的virtual function thunk,用于管理基类和多态的virtual function table thunk;自动实例化(非显式实例化)的泛型代码;还有虚表本身。

对于这些问题,大多可以通过避免使用这些C++语言特性来解决。

此外,内联函数本身,也可能导致问题。因为,它有可能没被内联,而是生成了一个普通的函数,而且取决于被调用的位置,它可能存在于多个代码段。这个可以用宏或者编译器扩展的__forceinline来替代。

二、堆分配
对普通应用而言,通常我们只用一个动态内存分配的堆。而在
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值