使用sysctl检测目前在iOS上运行的应用程序

前端之家收集整理的这篇文章主要介绍了使用sysctl检测目前在iOS上运行的应用程序前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我目前已经实施了一个简单的活动监视器来观看iOS上所有正在运行的进程.

要检索所有正在运行的进程的列表,请执行以下操作:

size_t size;
struct kinfo_proc *procs = NULL;
int status;
NSMutableArray *killedProcesses = [[NSMutableArray alloc] init];

int mib[4] = { CTL_KERN,KERN_PROC,KERN_PROC_ALL,0 };

status  = sysctl(mib,4,NULL,&size,0);
procs   = malloc(size);
status  = sysctl(mib,procs,0);

// now,we have a nice list of processes

如果我想要更多关于具体过程的信息,我会做:

struct kinfo_proc *proc;
int mib[5] = { CTL_KERN,KERN_PROC_PID,pidNum,0 };
int count;
size_t size = 0;

// ask the proc size
if(sysctl(mib,0) < 0) return -1;

// allocate memory for proc
proc = (struct kinfo_proc *)malloc(size);

sysctl(mib,proc,0);

我想要的所有额外的proc信息现在存储在proc中.

我注意到应用程序不会被操作系统杀死.即使应用程序长时间不使用(超过10分钟),它将保留在进程列表中.即使我查询进程的“state”(proc-> kp_proc.p_stat),它返回“running”.

我的问题是:有人知道一种方法来检测哪个PID正在运行/主动使用(也许:增加cpu时间?运行时间?cpu ticks等)?

解决方法

回答问题的“当前运行”部分:

我用这个答案Can we retrieve the applications currently running in iPhone and iPad代码

看看这里的k_proc声明:http://www.opensource.apple.com/source/xnu/xnu-1456.1.26/bsd/sys/proc.h

通过尝试和错误发现,p_flag设置为18432的进程是当前正在运行的应用程序(在本例中为此测试).

请参阅第一个链接,并将for循环的内部替换为:

if (process[i].kp_proc.p_flag == 18432){

                        NSString * processID    = [[NSString alloc] initWithFormat:@"%d",process[i].kp_proc.p_pid];
                        NSString * processName  = [[NSString alloc] initWithFormat:@"%s",process[i].kp_proc.p_comm];
                        NSString * status       = [[NSString alloc] initWithFormat:@"%d",process[i].kp_proc.p_flag ];

                        NSDictionary * dict = [[NSDictionary alloc] initWithObjects:[NSArray arrayWithObjects:processID,processName,status,nil]
                                                                            forKeys:[NSArray arrayWithObjects:@"ProcessID",@"ProcessName",@"flag",nil]];

                        [array addObject:dict];

}

猜你在找的iOS相关文章