C# 获取进程或线程的信息

2023-05-16

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Diagnostics;

 

namespace ConsoleApp

{

    class ProcessDo

    {

        /// <summary>

        /// 获取进程相关信息

        /// </summary>

        public static void GetProcessInfomation()

        {

            Process pro = Process.GetProcessesByName("QQ")[0];

            Console.WriteLine("进程名称:" + pro.ProcessName);

            Console.WriteLine("进程ID:" + pro.Id.ToString());

            Console.WriteLine("启动时间:" + pro.StartTime.ToLongDateString() + pro.StartTime.ToLongTimeString());

            Console.WriteLine("是否响应:" + pro.Responding.ToString());

            Console.WriteLine("关联进程句柄:" + pro.Handle.ToString());

            Console.WriteLine("进程打开的句柄数:" + pro.HandleCount.ToString());

            Console.WriteLine("主窗口句柄:" + pro.MainWindowHandle.ToString());

            Console.WriteLine("主窗口标题:" + pro.MainWindowTitle);

            Console.WriteLine("模块数量:" + pro.Modules.Count.ToString());

            Console.WriteLine("基本优先级:" + pro.BasePriority.ToString());

            Console.WriteLine("提升优先级:" + pro.PriorityBoostEnabled.ToString());

            Console.WriteLine("处理器:" + pro.ProcessorAffinity.ToInt32().ToString());

            Console.WriteLine("最小工作集:" + pro.MinWorkingSet.ToInt32().ToString());

            Console.WriteLine("最大工作集:" + pro.MaxWorkingSet.ToInt32().ToString());

            Console.WriteLine("工作集:" + pro.WorkingSet.ToString());

            Console.WriteLine("峰值工作集:" + pro.PeakWorkingSet.ToString());

            Console.WriteLine("专用内存大小:" + pro.PrivateMemorySize.ToString());

            Console.WriteLine("未分页内存大小:" + pro.NonpagedSystemMemorySize.ToString());

            Console.WriteLine("分页内存大小:" + pro.PagedMemorySize.ToString());

            Console.WriteLine("峰值分页内存大小:" + pro.PeakPagedMemorySize.ToString());

            Console.WriteLine("虚拟内存大小:" + pro.VirtualMemorySize.ToString());

            Console.WriteLine("峰值虚拟内存大小:" + pro.PeakVirtualMemorySize.ToString());

            Console.WriteLine("占用时间:" + pro.TotalProcessorTime.ToString());

            Console.WriteLine("特权占用时间:" + pro.PrivilegedProcessorTime.ToString());

            Console.WriteLine("用户占用时间:" + pro.UserProcessorTime.ToString());

 

        }

 

 

        /// <summary>

        /// 进程的线程详细信息

        /// </summary>

        public static void GetProcessThreadInfomation()

        {

            Process pro = Process.GetProcessesByName("QQ")[0];

            Console.WriteLine("QQ程序进程的线程详细信息如下:");

            int length = pro.Threads.Count;

            for (int i = 0; i < length; i++)

            {

                var thread = pro.Threads[i];

                Console.WriteLine("标识符:" + thread.Id.ToString());

                Console.WriteLine("基本优先级:" + thread.BasePriority.ToString());

                Console.WriteLine("当前优先级:" + thread.CurrentPriority.ToString());

                Console.WriteLine("内存地址:" + thread.StartAddress.ToInt32());

                Console.WriteLine("启动时间:" + thread.StartTime.ToString());

                Console.WriteLine("使用时间:" + thread.UserProcessorTime.ToString());

                Console.Write("当前状态:");

                switch (thread.ThreadState)

                {

                    case ThreadState.Initialized:

                        Console.WriteLine("线程已经初始化但尚未启动");

                        break;

                    case ThreadState.Ready:

                        Console.WriteLine("线程准备在下一个可用的处理器上运行");

                        break;

                    case ThreadState.Running:

                        Console.WriteLine("当前正在使用处理器");

                        break;

                    case ThreadState.Standby:

                        Console.WriteLine("线程将要使用处理器");

                        break;

                    case ThreadState.Terminated:

                        Console.WriteLine("线程已完成执行并退出"); 

                        break;

                    case ThreadState.Transition:

                        Console.WriteLine("线程在可以执行钱等待处理器之外的资源");

                        break;

                    case ThreadState.Unknown:

                        Console.WriteLine("状态未知");

                        break;

                    case ThreadState.Wait:

                        Console.WriteLine("正在等待外围操作完成或者资源释放");

                        break;

                    default:

                        break;

                }

                if (thread.ThreadState == ThreadState.Wait)

                {

 

                    Console.Write("等待原因:");

                    switch (thread.WaitReason)

                    {

                        case ThreadWaitReason.EventPairHigh:

                            Console.WriteLine("线程正在等待事件对高");

                            break;

                        case ThreadWaitReason.EventPairLow:

                            Console.WriteLine("线程正在等待事件对低");

                            break;

                        case ThreadWaitReason.ExecutionDelay:

                            Console.WriteLine("线程执行延迟");

                            break;

                        case ThreadWaitReason.Executive:

                            Console.WriteLine("线程正在等待计划程序");

                            break;

                        case ThreadWaitReason.FreePage:

                            Console.WriteLine("线程正在等待可用的虚拟内存页");

                            break;

                        case ThreadWaitReason.LpcReceive:

                            Console.WriteLine("线程正在等待本地过程调用到达");

                            break;

                        case ThreadWaitReason.LpcReply:

                            Console.WriteLine("线程正在等待对本地过程调用的回复到达");

                            break;

                        case ThreadWaitReason.PageIn:

                            Console.WriteLine("线程正在等待虚拟内存页到达内存");

                            break;

                        case ThreadWaitReason.PageOut:

                            Console.WriteLine("线程正在等待虚拟内存页写入磁盘");

                            break;

                        case ThreadWaitReason.Suspended:

                            Console.WriteLine("线程执行暂停");

                            break;

                        case ThreadWaitReason.SystemAllocation:

                            Console.WriteLine("线程正在等待系统分配");

                            break;

                        case ThreadWaitReason.Unknown:

                            Console.WriteLine("线程因位置原因而等待");

                            break;

                        case ThreadWaitReason.UserRequest:

                            Console.WriteLine("线程正在等待用户请求");

                            break;

                        case ThreadWaitReason.VirtualMemory:

                            Console.WriteLine("线程正在等待系统分配虚拟内存");

                            break;

                        default:

                            break;

                    }

                }

                Console.WriteLine();

             }

        }

 

        /// <summary>

        /// 限制应用程序运行时间

        /// 即关联程序超出设置的运行将自动关闭

        /// </summary>

        public static void GetKillAppForWaitTime()

        {

            Process proc = new Process();

            proc.StartInfo = new ProcessStartInfo(@"C:\Documents and Settings\zkk\桌面\mysql_20120925.sql");

            //启动应用程序

            proc.Start();

            //等待程序师徒完成载入

            proc.WaitForInputIdle();

            //等待程序结束执行

            proc.WaitForExit(3000);

            //如果程序在时间期限之前关闭,HasExited将会是true

            if (proc.HasExited == false)

            {

                //测试程序是否已经停止回应

                if (proc.Responding)

                {

                    //程序有回应,关闭主视图

                    proc.CloseMainWindow();

                }

                else

                {

                    //如果程序没有回应,将强制关闭

                    proc.Kill();

                }

            }

        }

    }

}

 

/******************************************

如果获得当前进程的Id用:

Process[] processes = Process.GetProcesses(); 
foreach(Process process in processes) 

if(process.ProcessName == "进程名" 

MessageBox.Show(process.Id); 

}

Process processes   =Process.GetCurrentProcess

processes.id获得当前进程的ID

如果获得当前线程的ID用:

Thread.CurrentThread.ManagedThreadId.ToString() (推荐)

AppDomain.GetCurrentThreadId().ToString()

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

C# 获取进程或线程的信息 的相关文章

  • C# 中Bitmap图像处理含增强对比度的三种方法

    Bitmap类 Bitmap对象封装了 xff27 xff24 xff29 43 中的一个位图 xff0c 此位图由图形图像及其属性的像素数据组成 因此Bitmap是用于处理由像素数据定义的图像的对象 该类的主要方法和属性如下 xff1a
  • c#获取控件指定坐标的像素值

    DllImport 34 gdi32 dll 34 private static extern uint GetPixel IntPtr hDC int XPos int YPos Graphics g 61 control CreateG
  • C#完美实现透明窗体的绘制效果

    为了实现透明窗体的绘制 xff0c 最开始是采用了双层窗体的模式 思路 xff1a 将form1的属性transparencyKey设置为背景色 xff0c 将form2的opicaty设置的很低 xff0c 比如0 05 保证鼠标不会穿透
  • CAS SSO 单点登录框架 学习

    1 了解单点登录 SSO 主要特点是 SSO 应用之间使用 Web 协议 如 HTTPS xff0c 并且只有一个登录入口 SSO 的体系中有下面三种角色 1 User 多个 2 Web 应用 多个 3 SSO 认证中心 一个 2 SSO
  • C# override详解

    重载 重写 覆写 xff0c 分别指的是overload override new 一 override重写 xff0c 是在子类中重写父类中的方法 xff0c 两个函数的函数特征 xff08 函数名 参数类型与个数 xff09 相同 用于
  • C# -WinForm 中英文实现, 国际化实现的简单方法

    来源 xff1a http www jb51 net article 45675 htm xff0c 今天看到了借鉴过了 xff0c 保存一下 xff0c 下次开发直接用嘻嘻 软件行业发展到今天 xff0c 国际化问题一直都占据非常重要的位
  • C#的Winform多语言实现(resx文件)

    使用resx文件实现Winform多语言切换 xff0c 本博文提供的代码可以实现简体中文 繁体中文 英文的切换 如果需要增加其它语言的切换 xff0c 只需要编写相应的语言的resx文件即可 并且 xff0c 当修改了语言之后 xff0c
  • c#中中读取嵌入和使用资源文件的方法

    Dotnet中嵌入资源 xff08 位图 图标或光标等 xff09 有两种方式 xff0c 一是直接把资源文件加入到项目 xff0c 作为嵌入资源 xff0c 在代码中通过Assembly的GetManifestResourceStream
  • c#中英文切换实例

    1 创建两个资源文件 Resource en US resx Resource zh CN resx 注意中间部分每种语言文件名固定 xff0c 后缀名是 resx 首部分是自定义的名字 2 创建读写工具类 上面两个资源文件都是在Utili
  • TCP/IP协议讲的明明白白

    从字面意义上讲 xff0c 有人可能会认为 TCP IP 是指 TCP 和 IP 两种协议 实际生活当中有时也确实就是指这两种协议 然而在很多情况下 xff0c 它只是利用 IP 进行通信时所必须用到的协议群的统称 具体来说 xff0c I
  • TCP/IP协议与Http协议的区别详解

    TPC IP协议是传输层协议 xff0c 主要解决数据如何在网络中传输 xff0c 而HTTP是应用层协议 xff0c 主要解决如何包装数据 关于TCP IP和HTTP协议的关系 xff0c 网络有一段比较容易理解的介绍 xff1a 我们在
  • C#中使用MD5对用户密码加密与解密

    C 中常涉及到对用户密码的加密于解密的算法 xff0c 其中使用MD5加密是最常见的的实现方式 本文总结了通用的算法并结合了自己的一点小经验 xff0c 分享给大家 一 使用16位 32位 64位MD5方法对用户名加密 1 xff09 16
  • C#中修改文件或文件夹的权限,为指定用户、用户组添加完全控制权限

    写在前面 在windows系统中 xff0c c盘中的目录权限比较高 xff0c 有时制作安装包的时候 xff0c 默认的安装路径就是在c盘 xff0c 但对运行可执行文件 xff0c 有时候需要为其添加完全控制权限 xff0c 或者读写权
  • C#使用SafeNet的开发狗和超级狗加密使用方法

    1 在安装光盘中选择Windows文件夹 xff0c 单击Setup exe执行安装程序 xff0c 安装过程默认选择 xff0c 单击下一步即可 2 安装完毕后插入超级狗 xff0c 在菜单栏中打开 超级狗开发商向导 xff0c 选择下载
  • Keil5 新建工程编译后Download按钮变灰

    Keil5 新建工程编译后Download按钮变灰 百度看到很多文章解决变灰方法为 这个主要目的是生成 HEX文件 xff0c 但有时候当你在线下载时点了Creat HEX File 并进行编译后 Download按钮依然呈现灰色 此时问题
  • C# SQLite 数据库操作语句与文件视图管理器

    sqlite数据库视图管理器 SQLiteSpy是一款专业的SQLite数据库管理 xff0c 主要用于读取sqlite数据库 xff0c 建立新的SQL查询 xff0c 视图 xff0c 复制和删除表 编辑单元格 xff0c 以及查看索引
  • C#JSON与XML相互转换

    using System using System Collections Generic using System Linq using System Text using System Xml using Newtonsoft Json
  • 让使用SQLite的.NET应用自适应32位/64位系统

    Windows 7 64 bit 刚扩到4G内存 果断换64位的 那速度杠杠的 Microsoft Visual Studio 2010 Ultimate 32bit 在64位系统里运行正常 sqlite netFx40 setup bun
  • WinForm 布局控件“WeifenLuo.WinFormsUI.Docking“的使用

    本篇介绍Winform程序开发中的布局界面的设计 xff0c 介绍如何在我的共享软件中使用布局控件 34 WeifenLuo WinFormsUI Docking 34 布局控件 34 WeifenLuo WinFormsUI Dockin

随机推荐

  • C#中JSON和对象之间互相转换功能示例

    本文实例讲述了C 实现JSON和对象之间互相转换功能 分享给大家供大家参考 xff0c 具体如下 xff1a 1 首先是声明用户信息对象 xff0c DataContract修饰类 xff0c 表示可以被解析成JSON xff0c Data
  • C#使用DataContractJsonSerializer来进行JSON解析

    在使用DataContractJsonSerializer进行解析之前 xff0c 我们首先需要将两个包引入进来 xff1a using System Runtime Serialization using System Runtime S
  • 步进电机驱动器脉冲频率确定 步进电机驱动器

    1 步进电机为什么要配步进电机驱动器才能工作 xff1f 步进电机作为一种控制精密位移及大范围调速专用的电机 它的旋转是以自身固有的步距角角 xff08 转子与定子的机械结构所决定 xff09 一步一步运行的 其特点是每旋转一步 xff0c
  • MFC添加自定义消息及重写消息过程

    由于MFC中无法通过类向导来自定义消息 xff0c 所以需要手动添加 xff0c 主要过程如下 xff1a 本文基于vs2008下通过线程实现数据实时更新的对话框运用程序 1 定义消息 xff08 Resource h文件中 xff09 x
  • C#操作注册表方法

    1 xff1a 要操作注册表 xff0c 我们必须要引入必要的命名空间 xff1a using Microsoft Win32 在这个命名空间里面包含了许多注册表相关的类 xff0c 足够我们使用了 2 xff1a 命名空间里面提供了一个类
  • 怎样测试ESP8266wifi模块?

    这里测试的方法是用USB TTL转换电路进行的测试 接线图如下所示 xff1a ESP8266引脚图如下 xff1a 因为ESP8266需要3 3V电压供电 xff0c 所以USB TTL的3 3V电压 xff0c GND分别与ESP826
  • Qt信号与槽机制

    一 简介 就我个人来理解 xff0c 信号槽机制与Windows下消息机制类似 xff0c 消息机制是基于回调函数 xff0c Qt中用信号与槽来代替函数指针 xff0c 使程序更安全简洁 信号和槽机制是 Qt 的核心机制 xff0c 可以
  • QT中手动释放堆中的对象(new 出来的)

    Qt内存自动释放有两个前提条件 xff1a 1 必须是QObject的派生类 2 必须指定了parent对象 即 xff1a Qt 中 父亲被删除的时候会自动销毁他的孩子 所以如果New出来的并且没有父亲 那么则需要手动删除它 需要 xff
  • c++指针概念回顾

    前言 复杂类型说明 要了解指针 多多少少会出现一些比较复杂的类型 所以我先介绍一下如何完全理解一个复杂类型 要理解复杂类型其实很简单 一个类型里会出现很多运算符 他们也像普通的表达式一样 有优先级 其优先级和运算优先级一样 所以我总结了一下
  • c语言指针详解(概念示例)

    指针是 xff23 语言中广泛使用的一种数据类型 运用指针编程是 xff23 语言最主要的风格之一 利用指针变量可以表示各种数据结构 xff1b 能很方便地使用数组和字符串 xff1b 并能象汇编语言一样处理内存地址 xff0c 从而编出精
  • C#中模态对话框释放问题

    以下实例中可以测出 xff0c 当一个模态对话框返回DialogResult的结果后 xff0c 对话框自动隐藏 xff0c 但对话框db并没有彻底释放掉 xff0c 因此 仍可以访问db中的成员 xff0c 想要彻底释放需要手动加上db
  • qt中设置窗体大小

    在我们的编程中 xff0c 我们有时候会想让我们的程序窗体固定大小 xff0c 而该大小是我们在编辑时的大小 经过我的摸索 xff0c 和查阅资料 找到了一个方法 其实也很简单 其实也就是先找到该窗体的物理大小 然后设置固定窗体的大小即可
  • c++ (QT)笔记

    1 标准情况下 xff0c c 43 43 中的类声明都在头文件中 xff0c 实现在 cpp文件中 xff0c 所以只在 cpp中实现类的函数在头文件中没有声明会报错 c 43 43 的函数实现和声明都可放在头文件中这样 cpp文件也可访
  • C语言中指针动态内存的申请和释放

    什么是动态内存的申请和释放 xff1f 当程序运行到需要一个动态变量时 xff0c 需要向系统的堆中申请一块内存 xff0c 用来存储这块变量 xff0c 这就是内存的申请 当程序不需要这个变量时 xff0c 就需要把申请的这块内存释放掉
  • Qt中线程使用汇总

    QThread类提供一种独立于平台的线程管理方式 方法1 一个QThread实例管理程序中的一个线程 QThread的执行开始于run 默认情况下 xff0c run 通过调用exec 启动事件循环 xff0c 并在线程内运行Qt事件循环
  • 对线程与进程的区别以及对多线程并发的理解

    一 线程与进程的区别 先简单说说线程与进程的概念 xff1a xff08 1 xff09 进程是指一个内存中运行的应用程序 xff0c 比如在Windows系统中 xff0c 一个运行的exe就是一个进程 xff08 2 xff09 线程是
  • 单片机学习经验总结

    单片机的学习是嵌入式中的裸机开发 xff0c 也就是不基于操作系统的开发过程 xff0c 你只要把自己学的程序下载到单片机内执行即可 xff08 这个过程有个专业术语 xff1a 烧写 xff09 在这个过程中 xff0c 你所写的程序 x
  • 三极管的工作原理(详细、通俗易懂、图文并茂)

    一 很多初学者都会认为三极管是两个 PN 结的简单凑合 xff08 如图1 xff09 这种想法是错误的 xff0c 两个二极管的组合不能形成一个三极管 我们以 NPN 型三极管为例 xff08 见图 2 xff09 xff0c 两个 PN
  • 三极管工作原理图解,快速了解三极管结构和工作原理

    了解三极管工作原理前 xff0c 先看一张三极管内部结构原理图 xff1b 从图中可以清晰的看出NPN和PNP内部结构的区别 三极管NPN型和PNP型的工作原理 xff1a NPN三极管 xff1a Vb lt Ve xff08 截止状态
  • C# 获取进程或线程的信息

    using System using System Collections Generic using System Linq using System Text using System Diagnostics namespace Con