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()

C# 获取进程或线程的信息相关推荐

  1. C# 获取进程或线程的相关信息

    参考文章:http://www.cnblogs.com/tommyli/p/4054296.html using System; using System.Collections.Generic; u ...

  2. python3 获取 进程id 线程id

    1.获取线程id import threading# 1 获取线程ID,NAME t = threading.currentThread() #线程ID print('Thread id : %d' ...

  3. jstack-查看Java进程的线程堆栈信息,锁定高消耗资源代码

    jstack主要用来查看某个Java进程内的线程堆栈信息.语法格式如下: jstack [option] pid jstack [option] executable core jstack [opt ...

  4. mfc怎么获取进程的线程数_2020年大厂喜欢这样问线程安全,这些知识点我整理好了

    2020年,截止目前,我收到了阿里巴巴.腾讯.美团.京东.快手等互联网大厂的面试邀请.求职是一场流程很长的拉锯战,涉及岗位选择.简历投递.简历评估.技术面试.HR面试等环节. 我发现在技术面试中多线程 ...

  5. 获取进程或线程的ID以及句柄信息

    先介绍一下创建线程或进程的时候是可以得到相应的ID以及句柄信息的. BOOL CreateProcess ( LPCTSTR lpApplicationName, LPTSTR lpCommandLi ...

  6. 进程,线程与信息共享

          按照传统的 Unix 编程模型,我们在一个系统上运行多个进程,每个进程都有各自的地址空间.Unix 进程间的信息共享可以有多种方式.下图说明了共享信息的三种方式:              ...

  7. mfc怎么获取进程的线程数_Python多线程获取小米应用商店App,看看我是怎么做到的

    一.[项目背景] 小米应用商店给用户发现最好的安卓应用和游戏,安全可靠,可是要下载东西要一个一个的搜索太麻烦了.而且速度并不是很快. 今天小编就教大家利用多线程爬取小米应用商店的游戏模块,快速获取我们 ...

  8. muduo:获取进程相关信息

    muduo里面有专门获取进程信息的类,记录一下. // Use of this source code is governed by a BSD-style license // that can b ...

  9. python psutil 进程cpu_python 模块psutil获取进程信息

    获取进程信息 接续上篇<python 常用内建模块之psutil>安装psutil,并且获取一些基本信息,本篇介绍通过psutil获取到所有进程的详细信息: 1. 获取所有进程ID pri ...

最新文章

  1. vconsole插件_手机前端开发调试利器 – vConsole
  2. android屏幕分享软件,ScreenStream(屏幕分享)
  3. stdthread(2)创建
  4. BLOB,TEXT GEOMETRY or JSON column 'xxx' can't have a default value query问题解决
  5. 数据库的范式总结(待续)
  6. 一维装箱、二维装箱、三维装箱 区别
  7. WPS表格 JSA 学习笔记
  8. 51单片机智能循迹小车的通俗易懂讲解
  9. PotPlayer和MPC-HC挂载VSFilterMod加载外挂特效字幕的方法
  10. 日更第1天:Linux常用命令之dnf用法
  11. MICCAI-iseg2017挑战赛小结与婴儿脑组织分割总结
  12. Canvas学习:绘制箭头
  13. 2022汽车驾驶员(初级)考试模拟100题及模拟考试
  14. 一维消消乐c语言数据结构,Python数据结构:一维开心消消乐
  15. 京东AI研究院梅涛:计算机视觉助力提升服务体验
  16. 大学四年要做的四件事
  17. 容器PaaS资源导航
  18. MATLAB 之 绘制三维图形的基本函数、三维曲面和其他三维图形
  19. 区块链+保险,隐私保护必不可少!
  20. 直链文件服务器,山寨云直链 服务器拒绝

热门文章

  1. 计算机网络技术超文本,网络协议确定了计算机网络传递和管理信息的规范,其中HTTP属于()A、超文本传输协议B、传输控制协...
  2. java类创建顺序,Java基础----你真的了解java类创建顺序吗?
  3. yoyo跑_面对“跑腿服务坑”:悠悠跑腿、蜂鸟配送、快跑者,跑腿公司该何去何从?...
  4. stm32 复位到内部bootloader
  5. 2015计算机二级c语言6,2015年计算机二级《C语言》最新章节练习题(6)
  6. 迭代反投影法代码_程序员的数学笔记3--迭代法
  7. pb界面框架开发_CATIA CAA二次开发草图界面框架类:CATSketcherCommands
  8. 我们学的技术会过时吗?甚至被淘汰?
  9. 为什么要做电路保护,电路保护的意义是什么?
  10. 真人出镜,微信视频号第一期视频来了!