linux schedul源码分析

本文深入解析了Linux内核中的任务调度器实现原理,包括任务状态转换、优先级调度及上下文切换等关键环节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

asmlinkage void schedule(void)
{
 task_t *prev, *next;
 runqueue_t *rq;
 prio_array_t *array;
 struct list_head *queue;
 int idx;

 #判断是否调度发生在中断上下文,如果是就出错;在LINUX的中断中是不允许发生调度的


 if (unlikely(in_interrupt()))   
  BUG();

need_resched:


 preempt_disable();
 prev = current;
 rq = this_rq();

 release_kernel_lock(prev, smp_processor_id());
 prepare_arch_schedule(prev);
 prev->sleep_timestamp = jiffies;
 spin_lock_irq(&rq->lock);

 
 if (unlikely(preempt_get_count() & PREEMPT_ACTIVE))
  goto pick_next_task;

 switch (prev->state) {
 case TASK_INTERRUPTIBLE:
  if (unlikely(signal_pending(prev))) {
   prev->state = TASK_RUNNING;
   break;
  }
 default:
  deactivate_task(prev, rq);
 case TASK_RUNNING:
  ;
 }
pick_next_task:
 if (unlikely(!rq->nr_running)) {
#if CONFIG_SMP
  load_balance(rq, 1);
  if (rq->nr_running)
   goto pick_next_task;
#endif
  next = rq->idle;
  rq->expired_timestamp = 0;
  goto switch_tasks;
 }

 array = rq->active;
 if (unlikely(!array->nr_active)) {
 
  rq->active = rq->expired;
  rq->expired = array;
  array = rq->active;
  rq->expired_timestamp = 0;
 }

 idx = sched_find_first_bit(array->bitmap);
 queue = array->queue + idx;
 next = list_entry(queue->next, task_t, run_list);

switch_tasks:
 prefetch(next);
 clear_tsk_need_resched(prev);

 if (likely(prev != next)) {
  rq->nr_switches++;
  rq->curr = next;
 
  prepare_arch_switch(rq);

  TRACE_SCHEDCHANGE(prev, next);

  prev = context_switch(prev, next);
  barrier();
  rq = this_rq();
  finish_arch_switch(rq);
 } else
  spin_unlock_irq(&rq->lock);
 finish_arch_schedule(prev);

 reacquire_kernel_lock(current);
 preempt_enable_no_resched();
 if (need_resched())
  goto need_resched;
}

 

本篇文章来源于 Linux公社网站(www.linuxidc.com)  原文链接:http://www.linuxidc.com/Linux/2011-04/35087.htm

定时任务在Java中通常通过`java.util.Timer`或更现代的`java.util.concurrent.ScheduledExecutorService`来实现。以下是简单的介绍: 1. **java.util.Timer**: 这是一个基于线程池的定时任务框架,它允许你在固定延迟或周期性时间间隔后执行指定的任务。你可以创建`TimerTask`实例,并将它们添加到`Timer`实例中,然后通过`schedule()`方法启动任务。 ```java import java.util.Timer; import java.util.TimerTask; public class Main { Timer timer = new Timer(); TimerTask task = new TimerTask() { @Override public void run() { // 你的业务逻辑 System.out.println("定时任务执行"); } }; public static void main(String[] args) { Main main = new Main(); // 每隔5秒执行一次 main.timer.schedule(task, 0, 5000); } } ``` 2. **java.util.concurrent.ScheduledExecutorService**: 这个API提供了更为强大的异步任务调度能力,支持周期性和一次性任务,以及定制化的延迟策略。`ScheduledFuture`接口让你可以获取对任务结果的访问,甚至取消任务。 ```java import java.util.concurrent.Executors; import java.util.concurrent.ScheduledExecutorService; import java.util.concurrent.TimeUnit; public class Main { ScheduledExecutorService executor = Executors.newSingleThreadScheduledExecutor(); public void scheduleTask(Runnable command, long delay, TimeUnit unit) { executor.schedule(command, delay, unit); } public static void main(String[] args) { Main main = new Main(); Runnable worker = () -> { // 你的业务逻辑 System.out.println("定时任务执行"); }; main.scheduleTask(worker, 5, TimeUnit.SECONDS); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值