美文网首页
不通时间任务分割执行

不通时间任务分割执行

作者: 醉于麦田 | 来源:发表于2020-04-14 18:00 被阅读0次

一个计划任务,有N个时间段,每个时间段执行不同的业务,时间段存在包含,不存在交集!

如何把业务分割出来执行而有不影响业务!在特定的时间段里,就要执行就近原则的业务!

以时间点为分割!

$list = [

  ['start'=>'08:00','end'=>'16:00','desc'=>'通用'],

  ['start'=>'09:00','end'=>'10:00','desc'=>'特殊'],

  ['start'=>'10:00','end'=>'11:00','desc'=>'检查'],

  ['start'=>'12:00','end'=>'13:00','desc'=>'午检'],

  ['start'=>'14:00','end'=>'15:00','desc'=>'上课'],

  ['start'=>'13:30','end'=>'16:00','desc'=>'wudu'],

  ['start'=>'17:00','end'=>'20:00','desc'=>'夜幕']

];

//对list进行排序

$lists = array();

$end_lsit = array();

foreach ($list as $key=>$val){

  $lists[$val['start']] = $val;

  $end_lsit[$val['end']] = $val;

}

ksort($lists);

ksort($end_lsit);

//取出所有时间点

$starts = array_column($list, 'start');

$ends = array_column($list, 'end');

$times = array_merge($starts,$ends);

$times = array_unique($times);

sort($times);

$list_data = array();

foreach ($times as $key=>$val){

  if (!empty($lists[$val])){

      if ($key < count($times) -1){

        if ($lists[$val]['end'] <= $times[$key+1]){

            $list_data[] = $lists[$val];

        }elseif ($lists[$val]['end'] > $times[$key+1]){

            $self_data = $lists[$val];

            $self_data['end'] = $times[$key+1];

            $list_data[] = $self_data;

        }

}

  }else{

      $self_lists = array();

      foreach ($lists as $keys=>$vals){

        if ($vals['start'] <= $val && $vals['end'] > $val){

            $self_lists[] = $vals;

        }

}

      $last_data = array();

      foreach ($self_lists as $keyss=>$valss){

        $last_data[(int)$valss['end'] - (int)$valss['start']] = $valss;

      }

      ksort($last_data);

      $last_data = array_values($last_data);

      if (!empty($last_data)){

        if($key < count($times) -1){

            if ($val != $times[$key+1]){

              if ($val != $times[$key+1]){

                  $last_data[0]['start'] = $val;

                  $last_data[0]['end'] = $times[$key+1];

              }

}

        }else{

            if ($val != $last_data[0]['end']){

              $last_data[0]['start'] = $val;

            }

}

        if (!empty($last_data)){

            $list_data[] = $last_data[0];

        }

}

}

}

print_r($list_data);

相关文章

  • 不通时间任务分割执行

    一个计划任务,有N个时间段,每个时间段执行不同的业务,时间段存在包含,不存在交集! 如何把业务分割出来执行而有不影...

  • 【多线程】dispatch_barrier_sync 和disp

    共同点和区别 共同点:分割queue中的任务任务执行 区别: 是否影响主线程代码的执行 dispatch_barr...

  • ForkjoinPool -1

    ForkJoin是用于并行执行任务的框架, 是一个把大任务分割成若干个小任务,最终汇总每个小任务结果后得到大任务结...

  • 作用域与作用域链

    1.作用域: 执行js的区域,与其他由"{}"分割区域的语言不通,js是有由function来划分区域的,分...

  • Timer的schedule和scheduleAtFixedRa

    相同点: 1.任务执行未超时, 下次执行时间=上次执行开始时间+period; 2.任务执行超时,下次执行时间=上...

  • 执行了时间任务表格

    今天执行了时间任务表格,希望自己能够抛去过去的坏习惯,做事情要做好,要有效率,而不是胡思乱想,搞一些没用的东西浪费...

  • 计划任务

    在指定的时间执行命令 at - 将任务排队,在指定的时间执行。 atq - 查看待执行的任务队列。 atrm - ...

  • Fork/Join框架

    Fork/Join框架是Java 7提供的一个用于并行执行任务的框架,是一个把大任务分割成若干 个小任务(Fork...

  • linux 定时任务

    任务计划/周期性任务执行 未来的时间点执行一次某任务: at batch周期性运行某任务: crontab以上执行...

  • [转]Java Fork/Join 框架

    简介 从JDK1.7开始,Java提供Fork/Join框架用于并行执行任务,它的思想就是讲一个大任务分割成若干小...

网友评论

      本文标题:不通时间任务分割执行

      本文链接:https://www.haomeiwen.com/subject/ozntvhtx.html