01 |
VOID RtlInitUnicodeString (OUT PUNICODE_STRING DestinationString,IN PCWSTR SourceString OPTIONAL) |
04 |
DestinationString->MaximumLength = 0; |
05 |
DestinationString->Length = 0; |
06 |
DestinationString->Buffer = ( PWSTR )SourceString; |
07 |
if (ARGUMENT_PRESENT(SourceString)) |
09 |
Length = wcslen(SourceString) * sizeof ( WCHAR ); |
10 |
ASSERT(Length < MAX_USTRING); |
11 |
if (Length >= MAX_USTRING) |
13 |
Length = MAX_USTRING - sizeof (UNICODE_NULL); |
15 |
DestinationString->Length = ( USHORT )Length; |
16 |
DestinationString->MaximumLength = ( USHORT )(Length + sizeof (UNICODE_NULL)); |
21 |
NTSTATUS RtlInitUnicodeStringEx ( OUT PUNICODE_STRING DestinationString,IN PCWSTR SourceString OPTIONAL) |
24 |
DestinationString->Length = 0; |
25 |
DestinationString->MaximumLength = 0; |
26 |
DestinationString->Buffer = ( PWSTR )SourceString; |
27 |
if (ARGUMENT_PRESENT(SourceString)) |
29 |
Length = wcslen(SourceString); |
31 |
if (Length > (UNICODE_STRING_MAX_CHARS - 1)) |
33 |
return STATUS_NAME_TOO_LONG; |
35 |
Length *= sizeof ( WCHAR ); |
36 |
DestinationString->Length = ( USHORT )Length; |
37 |
DestinationString->MaximumLength = ( USHORT )(Length + sizeof ( WCHAR )); |
39 |
return STATUS_SUCCESS; |
从以上代码可见,这2个函数会将传入的字符串指针直接赋值给结构体,这样的话,如果传入的是栈字符串,那么UNICODE_STIRNG只能在当前域内使用,不能存储到其他生命周期更长的地方,否则栈恢复以后读取到不正确的数据,
然而传入一个全局字符串是可以的,例如:
UNICODE_STRING str1;
void func()
{
WCHAR buf[]=L"lich";
RtlInitUnicodeString(&str1,buf);
}
这是错误写法
https://www.0xaa55.com/forum.php?mod=viewthread&tid=1371&extra=page%3D6
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
2015-06-03 程序不稳定是因为C++基础不扎实
2015-06-03 一个优势的公司基本不可能再被同样的产品颠覆了(应该创新,从而干掉旧的需求基础)
2015-06-03 Little-endian的一个好处:在变量指针转换的时候地址保持不变
2015-06-03 Delphi程序的自我修改