前面写了一篇C#实战030:如何区分前后台同名进程,这个主要是用来杀掉一些没用的后台进程,保留前台的操作,但是因为前台一直在运行,所以经常会调用很多的后台进程,所以刚杀掉的进程又会出来占用资源,目前每次都会手动的去运行这个程序来关闭进程,显然很繁琐,所以今天给它再添加一个功能,那就是定时运行,让程序在后台定期的查杀进程。
这里我们到的是System.Threading.Timer,所以这里我们要引入空间名:using System.Threading,这里我们将查杀后台进程的方法封装成一个静态方法:
public static void progress(object b)
{
Console.WriteLine("Start Kill Progress! {0}", DateTime.Now);
string pName = "进程名称";
string winName = "窗口标题名称";
Process[] pro = Process.GetProcessesByName(pName); //获取进程名为“****”的进程
int count = pro.Length; //获取进程数量
Console.WriteLine(count);
try
{
for (int i = 0; i < count; i++)
{
string title = pro[i].MainWindowTitle; //获取进程的窗口标题
Console.WriteLine("进程窗口标题:{0}", title);
if (title != winName) //判断此进程是否是要查找的进程,如果不是就杀掉该进程
{
pro[i].Kill(); //杀掉进程
}
}
}
catch (Exception)
{
throw;
}
}
现在我们只要在Main主函数中实例化一个定时器,然后调用这个方法即可,为了测试方便我打印了下当前时间,表示程序已经进入当前位置了,这里Timer有四个参数,TimerCallback 这是个委托,括号内是委托要执行的方法、null是指方法的参数,没有直接null、0指调用 委托中的progress方法之前延迟的时间、2000则是调用委托中的progress方法的时间间隔(这是的时间都是以毫秒为单位),上面的意思就是启动程序时立即执行progress方法,每次执行的时间间隔2秒。。
static void Main(string[] args)
{
try
{
Console.WriteLine("System.Threading.Timer {0}", DateTime.Now);
var time = new Timer(new TimerCallback(progress), null, 0, 2000);
Console.Read();
}
catch (Exception)
{
throw;
}
}
我们用Google浏览器来测试,在Chrome中打开多个网页,我们可以在任务管理器中看到,应用程序只显示你正浏览的页面标题,而在进程中却隐藏着多个进程,每个网页或者插件都会启动进程,这里我们可以保留标题为“百度一下,你就知道 - Google Chrome”的进程,然后将其他的进程全部杀掉。
先不使用定时器,直接修改proogress方法,添加一些提示信息方便我们确认操作是否执行正确,打印出当前的进程名和窗口名称,再把查杀状态显示出来,这样当查杀了就会显示progress killed,如果没有咋pass。
public static void progress(object b)
{
Console.WriteLine("Start Kill Progress! {0}", DateTime.Now);
string pName = "chrome";
string winName = "百度一下,你就知道 - Google Chrome";
Process[] pro = Process.GetProcessesByName(pName); //获取进程名为“****”的进程
int count = pro.Length; //获取进程数量
Console.WriteLine(count);
try
{
for (int i = 0; i < count; i++)
{
string title = pro[i].MainWindowTitle; //获取进程的窗口标题
string progress = pro[i].ProcessName; //获取进程名
Console.WriteLine("ProgressName:{0} - WindowsName:{1}", progress,title);
if (title != winName) //判断此进程是否是要查找的进程,如果不是就杀掉该进程
{
pro[i].Kill(); //杀掉进程
Console.WriteLine("{0} Killed", progress);
}else{
Console.WriteLine("Pass");
}
}
}
catch (Exception)
{
throw;
}
}
程序调试好了我们就开启定时器,执行程序我们发现进程被杀了,当我打开Chrome浏览器后你会发现页面都丢失了,而当你在开启新的窗口时Chrome浏览器会马上关闭,因为这时的窗口标题被改了,已经不再是“百度一下,你就知道 - Google Chrome",程序找不到这个进程自然就把所有的进程给杀了,Chrome随之关闭。
不想用委托,我们也可以直接设置定时器,我们直接把var time = new Timer(new TimerCallback(progress), null, 0, 2000);改写成var time = new Timer(progress, null, TimeSpan.FromSeconds(0), TimeSpan.FromSeconds(2));这样就直接调用progress方法,同样可以实现定时效果,这里的4个参数分别指的是:执行方法、方法参数、启动间隔时间、方法执行间隔时间。
以下是完整代码,有兴趣可以试试:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Threading;
using System.Diagnostics;
namespace timer
{
class Program
{
static void Main(string[] args)
{
try
{
Console.WriteLine("System.Threading.Timer {0}", DateTime.Now);
var time = new Timer(progress, null, TimeSpan.FromSeconds(0), TimeSpan.FromSeconds(2));
//var time = new Timer(new TimerCallback(progress), null, 0, 2000);
//progress(null);
Console.Read();
}
catch (Exception)
{
throw;
}
}
public static void progress(object b)
{
Console.WriteLine("Start Kill Progress! {0}", DateTime.Now);
string pName = "chrome";
string winName = "百度一下,你就知道 - Google Chrome";
Process[] pro = Process.GetProcessesByName(pName); //获取进程名为“****”的进程
int count = pro.Length; //获取进程数量
Console.WriteLine(count);
try
{
for (int i = 0; i < count; i++)
{
string title = pro[i].MainWindowTitle; //获取进程的窗口标题
string progress = pro[i].ProcessName; //获取进程名
Console.WriteLine("ProgressName:{0} - WindowsName:{1}", progress, title);
if (title != winName) //判断此进程是否是要查找的进程,如果不是就杀掉该进程
{
pro[i].Kill(); //杀掉进程
Console.WriteLine("{0} Killed", progress);
}
else
{
Console.WriteLine("Pass");
}
}
}
catch (Exception)
{
throw;
}
}
}
}