RtlUnicodeStringToCountedOemString 函数 (ntifs.h)
RtlUnicodeStringToCountedOemString 例程使用当前系统 OEM 代码页将指定的 Unicode 源字符串转换为计数的 OEM 字符串。
语法
NTSYSAPI NTSTATUS RtlUnicodeStringToCountedOemString(
POEM_STRING DestinationString,
[in] PCUNICODE_STRING SourceString,
[in] BOOLEAN AllocateDestinationString
);
参数
DestinationString
指向调用方分配的缓冲区的指针,用于接收计数的 OEM 字符串。 如果 AllocateDestinationString 为 FALSE,则调用方还必须为 DestinationString 的 Buffer 成员分配缓冲区以保存 OEM 数据。 如果 AllocateDestinationString 为 TRUE, 则 RtlUnicodeStringToCountedOemString 分配一个足够大的缓冲区来保存字符串,在 Buffer 中传递指向该字符串的指针,并相应地更新 DestinationString 的长度和最大长度成员。
[in] SourceString
指向要转换的源 Unicode 字符串的指针。
[in] AllocateDestinationString
如果 RtlUnicodeStringToCountedOemString 应为 DestinationString 分配缓冲区空间,则设置为 TRUE,否则设置为 FALSE。 如果此参数为 TRUE,则调用方负责通过调用 RtlFreeOemString 在不再需要缓冲区时释放缓冲区。
返回值
如果转换 DestinationString 中的字符串,RtlUnicodeStringToCountedOemString 将返回STATUS_SUCCESS。 否则,不会分配任何存储,也不会执行任何转换。 如果此例程无法转换给定 SourceString 中的字符,则返回STATUS_UNMAPPABLE_CHARACTER。
注解
RtlUnicodeStringToCountedOemString 返回不包含 NULL 终止符的已翻译字符串。 它使用在系统启动时作为当前系统代码页安装的 OEM 代码页来转换给定的源字符串。
RtlUnicodeStringToCountedOemString 不会修改源字符串。
有关其他字符串处理例程的信息,请参阅 运行时库 (RTL) 例程。
要求
要求 | 值 |
---|---|
目标平台 | 通用 |
标头 | ntifs.h (包括 Ntifs.h) |
Library | NtosKrnl.lib |
DLL | NtosKrnl.exe |
IRQL | < DISPATCH_LEVEL |
另请参阅
RtlOemStringToCountedUnicodeString