
要检索所有正在运行的进程的列表,请执行以下 *** 作:
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 sizeif(sysctl(mib,0) < 0) return -1;// allocate memory for procproc = (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];} 总结 以上是内存溢出为你收集整理的使用sysctl检测目前在iOS上运行的应用程序全部内容,希望文章能够帮你解决使用sysctl检测目前在iOS上运行的应用程序所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)