《Windows内核安全与驱动开发》 3.1 字符串操作
《Windows内核安全与驱动开发》阅读笔记 -- 索引目录
《Windows内核安全与驱动开发》 3.1 字符串操作
一、字符串的初始化
1. 判断下列代码为什么会蓝屏?
UNICODE_STRING str = { };
wcscpy(str.Buffer, L"hello world!");
str.Length = str.MaximumLength = wcslen(L"hello world!") * sizeof(WCHAR);
2. 编写代码,将一个 UNICODE_STRING 字符串给初始化为 L"hello world"
二、字符串的拷贝
1. 将字符串src的内容拷贝到字符串dst中。
UNICODE_STRING dst;
WCHAR dst_buf[];
UNICODE_STRING src = RTL_CONSTANT_STRING(L"hello world); //
// 自己需要补充的代码
//
2. RtlCopyUnicodeString 这种静态拷贝存在什么缺点?
三、字符串连接
1. 反思下列这行代码为什么会连接失败?
UNICODE_STRING str1;
RtlInitUnicodeString(&str1, L"hello");
UNICODE_STRING str2;
RtlInitUnicodeString(&str2, L" world!!");
RtlAppendUnicodeStringToString(&str1, &str2)
2. 下列初始化操作可行么?
UNICODE_STRING str1;
RtlInitUnicodeString(&str1, L"hello");
str1.MaximumLength = * sizeof(WCHAR);
UNICODE_STRING str2;
RtlInitUnicodeString(&str2, L" world!!");
NTSTATUS res = RtlAppendUnicodeStringToString(&str1, &str2);
if (res != STATUS_BUFFER_TOO_SMALL) {
DbgPrint("%wZ\n", &str1);
}
else {
DbgPrint("超出缓冲区!\n");
}
3. 尝试将 L"hello" 与 L" world!!" 两个字符串连接在一起,并判断是否超过缓冲区(STATUS_BUFFER_TOO_SAMLL)
4. 超出缓冲区的例子:

四、字符串打印
1. 已经初始化好了一个UNICODE_STRING str1,编写代码将其输出出来。
答案
一、字符串的初始化
1. 因为 UNICODE_STRING 的成员被初始化为0,此时 str.buffer 为空指针,在内核中会引发空指针异常,引发蓝屏。
2. 编写代码,将一个 UNICODE_STRING 字符串给初始化为 L"hello world"
UNICODE_STRING str = { };
RtlInitUnicodeString(&str, L"Hello world!");
二、字符串的拷贝
1. 将字符串src的内容拷贝到字符串dst中。
RtlInitEmptyUnicodeString(&dst, dst_buf, * sizeof(WCHAR));
RtlCopyUnicodeString(&dst, &src); // 字符串拷贝
2. RtlCopyUnicodeString 这种静态拷贝存在什么缺点?
答:最大范围不能超过dst的范围,如果超过,则拷贝不会成功,并且不会给出任何提示(之后会介绍动态拷贝字符串)。
三、字符串连接
1. str1的大小只允许其容纳 "hello",而之后的即使添加进来也不会出错,但返回值会给出 NTATUS_BUFFER_TOO_SMALL 的提示。
2. 不可行,str1.MaximumLength 在初始化时确定的,其对应的内存空间的大小,这样直接修改是无效的,内存写入时引发蓝屏。
3. 尝试将 L"hello" 与 L" world!!" 两个字符串连接在一起,并判断是否超过缓冲区(STATUS_BUFFER_TOO_SAMLL)
// 将str1初始化为 "hello",并且大小为256*sizeof(WCHAR)
UNICODE_STRING str = RTL_CONSTANT_STRING(L"hello");
UNICODE_STRING str1 = { };
WCHAR str1_buf[];
RtlInitEmptyUnicodeString(&str1, str1_buf, * sizeof(WCHAR));
RtlCopyUnicodeString(&str1, &str);
// 初始化str2 = " world!!"
UNICODE_STRING str2;
RtlInitUnicodeString(&str2, L" world!!");
NTSTATUS res = RtlAppendUnicodeStringToString(&str1, &str2);
// 判断执行结果
if (res != STATUS_BUFFER_TOO_SMALL) {
DbgPrint("%wZ\n", &str1);
}
else {
DbgPrint("超出缓冲区!\n");
}
四、字符串打印
1. 已经初始化好了一个 UNICODE_STRING str1,编写代码将其输出出来
DbgPrint("%wZ\n", &str1);
《Windows内核安全与驱动开发》 3.1 字符串操作的更多相关文章
- Windows内核安全与驱动开发
这篇是计算机中Windows Mobile/Symbian类的优质预售推荐<Windows内核安全与驱动开发>. 编辑推荐 本书适合计算机安全软件从业人员.计算机相关专业院校学生以及有一定 ...
- 《windows内核安全与驱动开发》ctrl2cap中的ObReferenceObjectByName疑问
国内有关于windows内核驱动这块的书籍实在是甚少,不过好在<windows内核安全与驱动开发>这本书还算不错(内容方面),但是不得不说这本书在许多地方存在着一些细节上的问题.比如我今天 ...
- 《Windows内核安全与驱动开发》 7.1&7.2&7.3 串口的过滤
<Windows内核安全与驱动开发>阅读笔记 -- 索引目录 <Windows内核安全与驱动开发> 7.1&7.2&7.3 串口的过滤 一.设备绑定的内核API ...
- 《Windows内核安全与驱动开发》阅读笔记 -- 索引目录
<Windows内核安全与驱动开发>阅读笔记 -- 索引目录 一.内核上机指导 二.内核编程环境及其特殊性 2.1 内核编程的环境 2.2 数据类型 2.3 重要的数据结构 2.4 函数调 ...
- 《Windows内核安全与驱动开发》 2.3 重要的数据结构
<Windows内核安全与驱动开发>阅读笔记 -- 索引目录 <Windows内核安全与驱动开发> 2.3 重要的数据结构 一.驱动对象 Windows内核采用__的编程方式 ...
- 《Windows内核安全与驱动开发》 3.2 内存与链表
<Windows内核安全与驱动开发>阅读笔记 -- 索引目录 <Windows内核安全与驱动开发> 3.2 内存与链表 1. 尝试生成一个链表头并将其初始化. 2. 尝试向内存 ...
- 《Windows内核安全与驱动开发》4.1 文件操作
<Windows内核安全与驱动开发>阅读笔记 -- 索引目录 <Windows内核安全与驱动开发>4.1 文件操作 从 C:\a.txt 中读取一部分内容并利用 DbgPrin ...
- 《Windows内核安全与驱动开发》4.3 时间与定时器
<Windows内核安全与驱动开发>阅读笔记 -- 索引目录 <Windows内核安全与驱动开发>4.3 时间与定时器 一.获取自系统启动以来的毫秒数 /* 函数作用:求自操 ...
- 《Windows内核安全与驱动开发》 4.4 线程与事件
<Windows内核安全与驱动开发>阅读笔记 -- 索引目录 <Windows内核安全与驱动开发> 4.4 线程与事件 一.开辟一个线程,参数为(打印内容+打印次数),利用线程 ...
随机推荐
- HTML基本单词《结构化标签》
- windows下安装nginx和基本配置
1.下载并安装nginx 到nginx官网上下载相应的安装包,http://nginx.org/en/download.html: 下载之后进行解压,将解压后的文件放到自己心仪的目录下,如下图所示: ...
- supervisord进程管理
一:简介 supervisord是一个进程管理工具,提供web页面管理,能对进程进行自动重启等操作. 优点: - 可以将非后台运行程序后台运行 - 自动监控,重启进程 缺点: - 不能管理后台运行程序 ...
- 大宇java面试系列(三):Redis常见面试题
1. Redis 是什么?都有哪些使用场景? 我们先来理解经典的CAP理论: 一致性:是指从数据层面来看的一致性. 可用性:是指从系统层面的可用性. 容错性:是指从网络层面的的容错性. 数据库逐渐从关 ...
- C++中对C的扩展学习新增内容———面向对象(继承)函数扩展性及虚函数机制
1.c语言中的多态,动态绑定和静态绑定 void do_speak(void(*speak)()) { speak(); } void pig_speak() { cout << &quo ...
- PHP Swoole长连接常见问题
连接失效问题例子其中,Redis常见的报错就是: 配置项:timeout报错信息:Error while reading line from the serverRedis可以配置如果客户端经过多少秒 ...
- Java基础:8种基本数据类型,取值范围和储存字节说明。
Java中,一共有8种基本数据类型: 4种整数型:int,short,long,byte. 2种浮点型:float,double. 1种字符类型:char. 1种表示真值的类型:boolean. [S ...
- nyoj 739 笨蛋难题四
笨蛋难题四 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 这些日子笨蛋一直研究股票,经过调研,终于发现xxx公司股票规律,更可喜的是 笨蛋推算出这家公司每天的股价, ...
- 【SpringBoot | Swagger】SpringBoot整合Swagger
SpringBoot整合Swagger 1. 什么是Swagger Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.简单说就是项目跑起来了, ...
- PHP的两种选择防止sql注入
1.使用PDO: $stmt = $pdo->prepare('SELECT * FROM user WHERE name = :name'); $stmt->execute(array( ...