草庐IT

​多进程

全部标签

windows - 获取名称/描述 Startaddress 或从进程中的线程 (Delphi/Pascal)

ProcessHacker在C中有一个进程管理器。当您在流程管理器中双击某个流程时,例如探索者您会看到很多信息,包括:与流程相关的主题。PDD、周期增量开始、地址、优先级。好吧,我尝试在Delphi中做类似的事情,但我只得到TID和优先级...我不能把信息开始地址如下:“msiltcfg.dll0x258!”或者只能返回00630EFA。(原始)应用程序黑客显示下图中的信息:我该如何解决这个问题?基于下面的代码示例。procedureTForm1.Button7Click(Sender:TObject);vartbi:THREAD_BASIC_INFORMATION;hThreadSn

windows - 将串行守护进程 + PHP 移植到 Windows

我有一个Linux系统:通过RS232端口与另一台设备通信的守护进程。一个php+javascript网站,通过socket。现在老板想知道把这些都移植到Windowze上需要付出多少努力。之前从未真正在Windows上编程过,我想问一下这将有多容易/困难,以及有哪些选择。谢谢, 最佳答案 PHP可能会按原样运行。Javascript在网络浏览器中运行,并将按原样运行。您的守护进程是Windows上的一项服务。显然,它通过javascript在套接字上监听来自网页的命令。您没有说明服务的目标语言是什么。某些语言(如C#dotNet)

windows - 如何从命令提示符终止进程及其父进程

我有一个从命令提示符启动的进程-file.bat,尽管它的父cmd.exe也需要终止。唯一的问题是还有cmd.exe的其他实例是否有终止进程file.bat的任何方法-而不删除cmd.exe的其他实例(我不能简单地终止cmd.exe进程,因为在这种情况下我不知道PID) 最佳答案 您可以尝试从Sysinternals解析PsList实用程序的输出。你可以从:http://technet.microsoft.com->搜索“sysinternals”当您运行“PsList-t”时,您会看到一个进程列表,子进程从左边距开始缩进。这是一个

Windows:WAITING进程完成

我必须制作一个简短的Windowsshell脚本。请不要逃跑。它再简单不过了,但我就是找不到让这个非常原始的命令行与我一起工作的方法。我只是想运行dxdiag,并对收集到的数据做一些事情。问题是,我无法让脚本等待dxdiag完成,因为它会生成进程并继续运行。在继续下一行之前,我需要文件存在并获得信息。使用start/wait没有效果,我猜是因为没有涉及GUI。我开始认为这是不可能的。请帮忙! 最佳答案 我试过这样的东西start/waitdxdiag/x:SomeXmlFile它在WindowsVista中对我有用。

windows - 是否可以将终止进程所需的所有信息保存到磁盘,然后重新启动它?

我正在考虑VM的工作方式,但在常规Windows操作系统进程的级别。我的想法是,如果我可以拍摄快照并卸载进程,我就永远不必因为用完RAM而退出另一个应用程序。 最佳答案 这在任何常见操作系统中都不实用。 关于windows-是否可以将终止进程所需的所有信息保存到磁盘,然后重新启动它?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/6317127/

c - 我怎样才能在 C 中获得一个进程句柄而不是它的名字?

我正在WindowsXP上编写程序,试图获取calc.exe的进程句柄。我可以假设用户确实运行了calc.exe,但他可能更改了文件名。即使名称已更改,是否有一个名称可以获取calc.exe进程的句柄?我找到了这个答案,但它不处理顽皮用户更改名称(例如更改为calc_new.exe)的情况:HowcanIgetaprocesshandlebyitsnameinC++?我可以使用Win32进程的一些其他属性来查找句柄吗? 最佳答案 您可以使用以下Win32API调用序列执行此操作:使用Spy++或类似工具找到您定位的顶级窗口的类名。调

windows - 将已执行进程的输出定向到当前 cmd

我能否以将执行程序的输出写入当前控制台的方式从JScript脚本执行程序?目前我正在使用Shell.Application.ShellExecute,它正在为已执行的应用程序打开另一个新控制台。在我的例子中,JScript是一个编译器的包装器,它由ShellExecute执行。所以发生的是所有编译器错误都丢失了,因为它们被打印在另一个控制台中。 最佳答案 如果您只担心捕获编译器输出,那么您可以将输出重定向到一个文件(我建议同时使用stdout和stderr)。像这样:varshell=newActiveXObject("WScrip

c++ - 将指向局部变量的指针传递给另一个进程有时有效,但有时无效

前阵子我写了一个程序,可以让你选择和修改窗口。它使用WindowFromPoint()获取鼠标光标下窗口的句柄,并调用GetWindowText()获取窗口的标题。这很好用。然后我添加了获取列表控件列标题的功能。问题在于,与返回宽度的GetColumnWidth()不同,没有相应的函数来获取标题。相反,获取列标题的标题需要将缓冲区传递给GetColumn()以填充标题。因此,当我将LVCOLUMN结构的pszText成员分配给指向缓冲区的指针并将该结构传递给GetColumn()时,其他进程将指针解释为在其自己的内存空间内。显然这是行不通的。我使用CodeProjectarticle中

c++ - QProcess::terminate() 不适用于简单的 Qt 应用程序作为 Windows XP 下的子进程

首先,我将从QProcess对象开始的简单Qt应用程序:#includeclassLOLProcess:publicQMainWindow{Q_OBJECTpublic:LOLProcess(QWidget*parent=0);~LOLProcess();protected:voidcloseEvent(QCloseEvent*);};LOLProcess::LOLProcess(QWidget*parent):QMainWindow(parent){}LOLProcess::~LOLProcess(){qDebug()现在,带有QProcess对象的Qt应用程序:#includecl

c++ - 在 64 位 Windows 中 Hook 32 位进程

我在window764位上使用键盘钩子(Hook)时遇到问题。我做这些事情:1.创建一个32位的dll2.加载到应用程序并设置WindowHookEx我已经成功连接到32位应用程序(Y!M、Skype...),但是当我连接到我的桌面或任何64位应用程序(记事本)时,该应用程序会卡住,直到我停止我的连接应用程序。我创建64位dll,在上面做同样的事情,并在32位进程中遇到同样的问题。所以,我认为问题出在我的32位dll中,无法注入(inject)到64位进程中。但是我不知道如何在窗口关注它时注入(inject)64位dll来处理。我想知道有什么方法可以做到,以及如何去做。或者我可以只Ho