2 acodem ACodeM 于 2016.05.05 13:43 提问

关于linux pthread 调度策略FIFO,抢占CPU的问题

Hi 各位
最近在学习pthread时有点儿疑问,两个thread1和thread2调度策略均为FIFO,优先级分别为10和30,thread1先创建出来,无限循环打印thread1。 3秒后,创建thread2,无限循环打印thread2.
我理解当thread2执行时,thread1就完全被抢占了,只有thread2被不停打印出来。但是结果却是thread1和thread2都会打印出来。
代码如下,麻烦各位大神帮忙解释一下,谢谢了

 #include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <sched.h>
pthread_t createSchedFifoThread(void* (*pThreadFunc)(void*), int priority)
{
        struct sched_param param;
        int policy;
        int ret;
        pthread_t id = 0;

        pthread_attr_t thread_attr;
        ret = pthread_attr_init(&thread_attr);
        if (0 != ret) {
                printf("Attribute creation failed");
                return id;
        }

        ret = pthread_attr_setschedpolicy(&thread_attr, SCHED_FIFO);
        if (0 != ret) {
                printf("pthread_attr_setschedpolicy failed");
                return id;
        }

        param.sched_priority = priority;

        ret = pthread_attr_setschedparam(&thread_attr, &param);
        if (0 != ret) {
                printf("Setting pthread_attr_setschedparam failed");
                return id;
        }

        ret = pthread_create(&id, &thread_attr, pThreadFunc, NULL);
        if (0 != ret) {
                printf("Thread creation failed");
                return id;
        }

        pthread_attr_destroy(&thread_attr);
        return id;
}

void* thread1(void *arg)
{
        while(1)
        {
                printf("thread1\n");
        }
}

void* thread2(void *arg)
{
        while(1)
        {
                printf("thread2\n");
        }
}

int main(void)
{
        pthread_t id;
        printf("create thread1\n");
        id = createSchedFifoThread(thread1, 10);
        sleep(3);
        printf("create thread2\n");
        id = createSchedFifoThread(thread2, 30);
        while(1)
        {
                sleep(1);
        }
        return 0;
}

1个回答

CSDNXIAOD
CSDNXIAOD   2016.05.05 13:52

浅谈pthread和Linux调度策略
浅谈pthread和Linux调度策略
linux进程调度之 FIFO 和 RR 调度策略
----------------------biu~biu~biu~~~在下问答机器人小D,这是我依靠自己的聪明才智给出的答案,如果不正确,你来咬我啊!

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
线程调度策略SCHED_RR(轮转法)和SCHED_FIFO(先进先出)之对比
我们在用pthread创建线程时,可以指定调度策略policy——SCHED_OTHER(默认)、SCHED_RR和SCHED_FIFO。这里TALK一下两个实时策略——SCHED_RR和SCHED_FIFO。 先看一下效果,我们创建了四个子线程,指定最高优先级(针对特定策略): SCHED_RR SCHED_FIFO 对相同优先级的任务
linux内核的三种主要调度策略
linux内核的三种主要调度策略: 1,SCHED_OTHER 分时调度策略,  2,SCHED_FIFO实时调度策略,先到先服务  3,SCHED_RR实时调度策略,时间片轮转    实时进程将得到优先调用,实时进程根据实时优先级决定调度权值。分时进程则通过nice和counter值决定权值,nice越小,counter越大,被调度的概率越大,也就是曾经使用了cpu
【多线程编程】线程调度策略及优先级
通过之前的学习我知道了当前 Linux 系统下任务调度策略主要有三种: 1、SCHED_OTHER:普通任务调度策略。 2、SCHED_FIFO:实时任务调度策略,先到先服务。一旦占用cpu则一直运行,直到有更高优先级任务到达或自己放弃。 3、SCHED_RR:实时任务调度策略,时间片轮转。当任务的时间片用完,系统将重新分配时间片,并置于就绪队列尾。放在队列尾 保证了所有具有相同优先级的R
pthread线程优先级的调度
如果系统定义了 _POSIX_THREAD_PRIORITY_SCHEDULING ,则支持设置线程的实时调度优先级。 我们可以用下面的编译指令来判断:#if defined(_POSIX_THREAD_PRIORITY_SCHEDULING)  调度策略 policy: 可以取三个值(SCHED_FIFO、SCHED_RR、SCHED_OTHER)。
linux进程调度算法:分时调度策略、FIFO调度策略、RR调度策略
linux内核的三种调度方法: SCHED_OTHER 分时调度策略, SCHED_FIFO实时调度策略,先到先服务 SCHED_RR实时调度策略,时间片轮转 注意: 实时进程将得到优先调用,实时进程根据实时优先级决定调度权值,分时进程则通过nice和counter值决定权值,nice越小,counter越大,被调度的概率越大,也就是曾经使用了cpu最少的进程将会得到优先
浅析Linux线程调度
在Linux中,线程是由进程来实现,线程就是轻量级进程( lightweight process ),因此在Linux中,线程的调度是按照进程的调度方式来进行调度的,也就是说线程是调度单元。Linux这样实现的线程的好处的之一是:线程调度直接使用进程调度就可以了,没必要再搞一个进程内的线程调度器。在Linux中,调度器是基于线程的调度策略(scheduling policy)和静态调度优先级(st
linux内核调度策略SCHED_OTHER,SCHED_FIFO和SCHED_RR
本文主要是看了大神的这篇文章:http://blog.chinaunix.net/uid-24774106-id-3379478.html 自己稍作总结而已。跟进程调度策略相关的代码为://调度策略 #define SCHED_OTHER 0 #define SCHED_FIFO 1 #define SCHED_RR 2 #ifdef __USE_GNU # define SCHED_BATCH
Linux 任务调度策略
Linux任务调度策略linux内核的三种调度方法 SCHED_OTHER 分时调度策略 SCHED_FIFO实时调度策略,先到先服务 SCHED_RR实时调度策略,时间片轮转
linux进程/线程调度策略(SCHED_OTHER,SCHED_FIFO,SCHED_RR)
linux内核的三种 调度策略 :  SCHED_OTHER 分时调度策略,(默认的)SCHED_FIFO实时调度策略,先到先服务SCHED_RR实时调度策略,时间片轮转        实时进程将得到优先调用,实时进程根据实时优先级决定调度权值,分时进程则通过nice和counter值决定权值,nice越小,counter越大,被调度的概率越大,也就是曾经使用了cpu最少的进程将会得到优先
Linux进程时间片的分配(调度策略和参数)
在多进程系统中,多个进程“同时”运行,这里并不是真正意义上的同时运行,而是多个进程在时间片上面交换运行(每个进程运行一个时间片,然后切换到下一个时间片运行)。 1.调度策略和参数 在Linux系统中,对于每个进程,需要设定一个相应的调度策略和参数,在系统中,处理多进程的方式为“抢占”式的(一个进程使用CPU直至系统抢占CPU给另一个进程使用) 设定和获取进程的调度策略和参数调用如下函数: