跨进程读写内存

在这里插入图片描述
解决方法是把数据写到高2G内存,然后切换cr3.把高2G的数据写入到目标程序。
在这里插入图片描述

//提升IRQL

//保存原来的Cr3
mov eax,cr3
mov OldCr3,eax

//切换Cr3
mov cr3,TargetCr3  //把自己进程的Cr3替换成目标进程的

//访问目标指定内存  这时候访问的就是别的进程的数据
mov eax,dword ptr ds:[0x401234]
//现在得到了数据就可以随便自己处理了

//self handle

//恢复原来的Cr3
mov eax,OldCr3
mov cr3,eax
//恢复IRQL
### 回答1: 在 Qt 中,可以通过使用 QProcess 类来创建和管理多个进程。QProcess 提供了一种简单的方式来启动外部程序或可执行文件。 要实现内部多进程进程通信,在不同的进程之间传递数据,Qt 提供了以下几种方式: 1. 信号与槽:可以通过信号与槽机制来实现多进程之间的通信。一个进程可以发送信号,其他进程可以通过槽函数接收并处理该信号。Qt 的信号与槽机制在多进程通信中具有较好的扩展性和灵活性。 2. 套接字:使用 Qt 的 QLocalSocket 和 QLocalServer 类,可以在本地进程之间建立套接字连接,实现进程通信。其中,QLocalServer 作为服务器端监听本地套接字连接请求,而 QLocalSocket 建立与服务器端的连接,进程之间可以通过套接字进行数据交互。 3. 共享内存:Qt 提供了 QSharedMemory 类来实现多进程共享内存的通信。可以创建一个 QSharedMemory 实例,并在不同的进程之间通过读写内存来传递数据。共享内存通信效率高,但需要确保数据的同步和互斥。 4. 本地文件:进程可以通过读写本地文件来实现进程通信。一个进程将数据入本地文件,其他进程可以读取该文件来获取数据。Qt 的 QFile 类提供了对本地文件的操作和管理。 需要注意的是,虽然可以通过以上方式实现进程通信,但多进程编程涉及到进程间的同步和互斥,需要特别留意数据的线程安全性。此外,需要小心避免进程间的死锁和竞态等多线程相关问题。 ### 回答2: Qt内部多进程进程通信的实现主要是通过Qt的平台 IPC(进程间通信)机制来实现的。Qt提供了多种方式用于进程间通信,包括信号槽机制、局域套接字(Local Socket)、共享内存(Shared Memory)等。 其中,信号槽机制是Qt最常用的进程间通信方式之一。通过该机制,可以在不同进程中的对象之间进行信号的发送和接收,实现进程间的通信。在Qt中,使用QSharedMemory类可以实现共享内存,通过共享内存可以将数据共享给其他进程,实现进程间的数据交互。 另外,局域套接字也是一种常见的Qt进程通信方式。通过使用QLocalServer和QLocalSocket类,可以在不同进程之间建立本地套接字连接,并通过读写套接字来进行进程间数据交互。 除了以上两种方式,Qt还提供了平台的消息队列、进程间信号等收发机制,在不同平台之间实现进程间通信。 总的来说,Qt提供了多种进程通信的方式,可以根据实际需要选择合适的方式来实现进程间的数据交互和通信。无论是信号槽机制、局域套接字还是共享内存,Qt都提供了相应的类和函数来简化进程通信的开发。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值