草庐IT

operator_id

全部标签

windows - 将硬盘盘符转换为相应的设备 ID(反之亦然)

我需要识别硬盘驱动器设备制造商ID的驱动器盘符(或者反之亦然,我也可以这样做)。检索制造商ID的命令:WMIC.exeDiskDriveGet/Format:List示例输出(拆分并使用格式化的HTML实体):PNPDeviceID=DISK&VEN_WDC_WD10&PROD_02FAEX-00Z3A0获取盘符的命令:WMIC.exeVolumeGet/Format:List示例输出:DriveLetter=C:问题是我无法从两个输出中找到任何有用的属性来进行查询,我的意思是我不知道如何处理制造商ID来搜索每个ID的驱动器号,我看不到任何方法来识别ID的驱动器号。因此,在我获得Dev

c++ - 在 Vista 上调用 RPC 调用时为 "operation is not supported"

我的应用程序使用MicrosoftRPC进行进程间通信。当两个进程在同一台机器上运行并且一个进程试图调用声明为(IDL符号)的方法时:error_status_trpcMethod([in]pipebyteparameter);此调用因RPC_S_CANNOT_SUPPORT(“不支持请求的操作”)而失败,并且永远不会到达服务器端,并且永远不会调用所提供管道的push()/pull()原语。这仅在使用ncalrpc协议(protocol)时在Vista上重现,否则不会重现。我还在事件查看器日志中发现了以下内容:应用程序(“我的程序exe文件名”\service)(PID:344)正在使

windows - 更改线程 session ID

如何在不同的session中启动线程?我需要从非交互式session(session0)中的服务启动交互式session(session1)中的线程。我之前通过使用SetTokenInFormation和DuplicateTokenEx然后将其传递给CreateProcessAsUser来完成此过程。我希望我可以做同样的事情,除了使用SetThreadToken而不是CreateProcessAsUser。 最佳答案 线程不属于session,进程属于。您需要在另一个session中创建一个进程来托管您想要的线程。

c# - 在重新安装和驱动器更改期间保持不变的持久系统/处理器 ID (C#)

我希望为我管理的某些嵌入式系统生成唯一ID。这些系统运行的是WindowsEmbedded7Standard和.NET4.0。ID必须:相对独特——每个嵌入式系统都在相同的主板、驱动器等上运行,我不会有冲突。坚持重新安装——这些计算机会定期使用我们软件的新版本进行重新镜像。不能依赖磁盘序列号——我们使用的不是真正的磁盘,而是带有CF转SATA适配器的CF卡,并且CF卡偶尔会被换掉。此外,我的机器中有多个NIC,因此只有有人能告诉我如何识别板载NIC和USB设备时,依赖板载NICMAC地址才有效。经过进一步研究,这似乎在托管代码的范围内是不可能的。完成此任务的最佳方法是什么?

c++ - 来自 D3D 显示适配器 ID 的描述性监视器名称

正如问题所暗示的,我试图提取一个描述性的监视器名称以匹配显示适配器名称。下面的代码给了我一个像\.\DISPLAY1这样的设备ID,这是可以理解的,但不是我要找的。//Getname.D3DADAPTER_IDENTIFIER9d3dID;d3d9.Get().GetAdapterIdentifier(iAdapter,0,&d3dID);dispAd.name=d3dID.Description;//AddmonitorIDtodisplayadaptername.FIX_ME//Nothappywiththisyet!HMONITORhMonitor=d3d9.Get().GetA

windows - GetLastError返回ERROR_OPERATION_ABORTED时,GetOverlappedResult的lpNumberOfBytesTransfered参数是否有效?

在我的项目中,我需要读取和写入串行端口(RS232)。我正在使用重叠IO并使用两个单独的线程进行读取和写入。当我发出一个没有立即完成的写操作时,我开始等待(WaitForMultipleObjects)两个事件;分配给重叠结构的hEvent成员的事件,以及一个停止事件。当我想停止线程时,我通过调用SetEvent()发出停止事件信号。这会导致等待函数返回。因为写入操作仍处于挂起状态,所以我通过调用CancelIO()取消了该操作。然后,我再次等待操作完成,现在使用GetOverlappedResult()并将bWait参数设置为True。当操作完成时,GetOverlappedResu

windows - 为什么在Win7 64bit下 'ntQuerySystemInformation'无法获取大于65535的进程id?

我使用“ntQuerySystemInformation”获取所有句柄信息,例如:NtQuerySystemInformation(SystemHandleInformation,pHandleInfor,ulSize,NULL);//SystemHandleInformation=16pHandleInfor的结构是:typedefstruct_SYSTEM_HANDLE_INFORMATION{ULONGProcessId;UCHARObjectTypeNumber;UCHARFlags;USHORTHandle;PVOIDObject;ACCESS_MASKGrantedAcce

windows - 如何生成字符串类型ID的资源条目?

我有一个包含以下条目的.rc文件:01111my_res{"string1"}01113my_res{"string2"}01119my_res{"string3"}当我用rc.exe编译这个.rc文件时,资源条目ID变为1111,1113和1119分别。显然,资源编译器将ID视为数字。我的第一印象是.res文件不能将数字存储为字符串类型。但是当使用资源编辑器(例如:XNResourceEditor.exe将资源ID1111更改为01111并存储为01111时,这表明资源ID可能存储为字符串类型。有没有办法将数字资源id编译为字符串类型? 最佳答案

c++ - 当程序可见或最小化时进程 ID 发生变化

这个问题在这里已经有了答案:NameofprocessforactivewindowinWindows8/10(4个答案)关闭5年前。我正在尝试获取程序的进程ID(PID),但由于某些奇怪的原因,PID发生了变化。当目标程序(Alarms&Clock)可见时,它给了我错误的PID,而将程序最小化给了我正确的PID。我猜测最小化目标程序暂停它的进程,从而允许读取它。但是,即使进程正在运行,简单地读取PID也不应成为限制。有人知道我做错了什么吗?目前尝试过的方法:以管理模式运行为64位编译为32位编译这是描述问题的一段有效的、简洁的代码:#include#include#includein

C++ 从线程 ID 列表中查找 GUI 线程

我正在用C++构建一个应用程序,它使用WindowsHook来控制第三方程序。我正在制作的程序是一个教程程序,用于展示如何使用这些第三方程序。我可以找到我想要挂接的第三方程序的进程ID,然后我可以查询这个进程ID以找到一个线程ID列表,用作WindowsAPI函数SetWindowsHookEx的参数。但是,我担心从正在运行的进程的线程ID列表中,我会挂接到一个可能随时结束的线程。理想情况下,我想连接到运行主gui的线程,这很可能是最长生命的线程之一(即使它不是最长生命的线程,教程程序也被设计为与GUI一起工作所以它仍然是理想的)。如果第三方应用程序有多个图形用户界面,那么我想找到主图