OJ判题核心实现(获取时间消耗、空间消耗)wait4、vfork实现

您所在的位置:网站首页 湖南都市在线看 OJ判题核心实现(获取时间消耗、空间消耗)wait4、vfork实现

OJ判题核心实现(获取时间消耗、空间消耗)wait4、vfork实现

2024-07-15 21:02:11| 来源: 网络整理| 查看: 265

判题需要几个步骤:

1.在linux搭建编译器环境:gcc g++ java python2 python3 pascal

2.根据源码的类型创建相应的源文件(.c .cpp .java 等)

3.编译对应的源文件

4.运行程序,使用测试用例测试得出时间消耗和内存消耗。

步骤中其实最难的就是第四步,怎么获得程序的时间消耗和空间消耗?有个思路:开线程运行该程序得到进程pid,然后主线程开个死循环不断通过这个pid,查出这个程序的内存消耗,比较保存一个最大的空间消耗值,轮训过程中判断运行时间是否超过规定时间,如果超过,那么kill该进程直接得出结果(TLE)。

这样求得的时间消耗其实不是很准的,比如说机器的其他计算任务很多,那么很多时间这个进程是处于就绪等待的状态,也就是没用CPU,什么都不做,这样的话,原本能跑过的程序我们也判为TLE了。获取进程的时间linux内核提供的有的,接下来会有演示怎么用。

判题流程:

 

核心命令:

vfork();创建子进程 setrlimit(RLIMIT_CPU, &rl);设置子进程的时间、内存限制 execvp(args[0],args);运行可执行程序 wait4(pid, &status, 0, &ru);回收子进程 判别子进程退出的类别(超时或者超内存)

第一步:vfork一个进程出来用于运行这个可执行程序

demo:创建一个子进程,获得pid

#include #include #include int main() { int pid = vfork(); if(pid < 0) printf("error in fork!\n"); else if (pid == 0) { printf("this is child, pid is %d\n", getpid()); int newstdin = open(in,O_RDWR|O_CREAT,0644); int newstdout=open(out,O_RDWR|O_CREAT,0644); dup2(newstdout,fileno(stdout)); dup2(newstdin,fileno(stdin)); exit(0); }else if (pid > 0) { printf("this is parent, pid is %d\n", getpid()); } return 0; }


【本文地址】

公司简介

联系我们

今日新闻


点击排行

实验室常用的仪器、试剂和
说到实验室常用到的东西,主要就分为仪器、试剂和耗
不用再找了,全球10大实验
01、赛默飞世尔科技(热电)Thermo Fisher Scientif
三代水柜的量产巅峰T-72坦
作者:寞寒最近,西边闹腾挺大,本来小寞以为忙完这
通风柜跟实验室通风系统有
说到通风柜跟实验室通风,不少人都纠结二者到底是不
集消毒杀菌、烘干收纳为一
厨房是家里细菌较多的地方,潮湿的环境、没有完全密
实验室设备之全钢实验台如
全钢实验台是实验室家具中较为重要的家具之一,很多

推荐新闻


图片新闻

实验室药品柜的特性有哪些
实验室药品柜是实验室家具的重要组成部分之一,主要
小学科学实验中有哪些教学
计算机 计算器 一般 打孔器 打气筒 仪器车 显微镜
实验室各种仪器原理动图讲
1.紫外分光光谱UV分析原理:吸收紫外光能量,引起分
高中化学常见仪器及实验装
1、可加热仪器:2、计量仪器:(1)仪器A的名称:量
微生物操作主要设备和器具
今天盘点一下微生物操作主要设备和器具,别嫌我啰嗦
浅谈通风柜使用基本常识
 众所周知,通风柜功能中最主要的就是排气功能。在

专题文章

    CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭