linux利用setpriority调整线程优先级,测试优先级对线程的影响
2013-08-22 09:34
330 查看
以下测试是为了验证setpriority函数对线程是否有效,理论上linux kernel是不区分调度是不区分线程和进程的。
用户线程和进程的区别是是否有独立的用户地址空间,线程的是共享的。
编译以下代码,运行 ./cpuidle.app 19 -19
可以看到打印 -19 优先级的线程打印会比 19优先级的线程多 400多次, 几乎满屏都是 -19优先级的打印。
当有-19的线程运行,整个系统都要明显卡顿和19的线程相比。
以上愚见或许有不对之处,请多多包涵。
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/time.h>
#include <pthread.h>
#include<sys/resource.h>
static void *cpuidle_loop(void *arg)
{
int pri;
int size = 0, sum = 0;
unsigned long long int loopCnt=0;
struct timeval tv;
int ret;
pri = *(int *)arg;
printf("[%s]pri=%d\n", __func__, pri);
setpriority(PRIO_PROCESS, 0, pri);
do{
sum+=size;
size += 10;
loopCnt+=10;
if(0==(loopCnt%1000000)){
printf("pri[%d]loopCnt=%lld\n", pri, loopCnt);
}
}while(1);
printf("size2=%d\n", size);
pthread_exit(NULL);
return NULL;
}
int main(int argn, char *argc[])
{
int i=50;
int pri = 0, pri2=0;
int size = 0, sum = 0;
pthread_t thread_id, thread_id2;
printf("arg1=%s\n", argc[1]);
pri = strtol(argc[1], NULL, 10);
pri2 = strtol(argc[2], NULL, 10);
printf("main pri=%d, pri2=%d\n", pri, pri2);
pthread_create(&thread_id, NULL, cpuidle_loop, &pri);
pthread_create(&thread_id2, NULL, cpuidle_loop, &pri2);
do{
sum+=size;
size += 10;
sleep(10);
}while(1);
printf("size=%d\n", size);
EXIT:
exit(0);
}
用户线程和进程的区别是是否有独立的用户地址空间,线程的是共享的。
编译以下代码,运行 ./cpuidle.app 19 -19
可以看到打印 -19 优先级的线程打印会比 19优先级的线程多 400多次, 几乎满屏都是 -19优先级的打印。
当有-19的线程运行,整个系统都要明显卡顿和19的线程相比。
以上愚见或许有不对之处,请多多包涵。
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/time.h>
#include <pthread.h>
#include<sys/resource.h>
static void *cpuidle_loop(void *arg)
{
int pri;
int size = 0, sum = 0;
unsigned long long int loopCnt=0;
struct timeval tv;
int ret;
pri = *(int *)arg;
printf("[%s]pri=%d\n", __func__, pri);
setpriority(PRIO_PROCESS, 0, pri);
do{
sum+=size;
size += 10;
loopCnt+=10;
if(0==(loopCnt%1000000)){
printf("pri[%d]loopCnt=%lld\n", pri, loopCnt);
}
}while(1);
printf("size2=%d\n", size);
pthread_exit(NULL);
return NULL;
}
int main(int argn, char *argc[])
{
int i=50;
int pri = 0, pri2=0;
int size = 0, sum = 0;
pthread_t thread_id, thread_id2;
printf("arg1=%s\n", argc[1]);
pri = strtol(argc[1], NULL, 10);
pri2 = strtol(argc[2], NULL, 10);
printf("main pri=%d, pri2=%d\n", pri, pri2);
pthread_create(&thread_id, NULL, cpuidle_loop, &pri);
pthread_create(&thread_id2, NULL, cpuidle_loop, &pri2);
do{
sum+=size;
size += 10;
sleep(10);
}while(1);
printf("size=%d\n", size);
EXIT:
exit(0);
}
相关文章推荐
- linux下调整进程、线程优先级
- RabbitMQ/JAVA 客户端测试(补:利用线程)
- Linux下线程的调度策略与优先级(二)
- java 多线程(2) 线程的调度和优先级 / sleep() / interrupt() 打断join() / yield() / setPriority()
- Linux线程属性及优先级设置
- Linux下线程的调度策略与优先级
- linux内核调度和线程优先级
- linux 实时线程优先级问题——数值越大优先级越高吗?
- 进程和线程(修改优先级 Windows IPC 应用移植到 Linux)
- linux中使用pthread_kill函数测试线程是否存活
- LINUX环境下SVN安装与配置(利用钩子同步开发环境与测试环境)
- linux中使用pthread_kill函数测试线程是否存活
- Linux线程属性及优先级设置
- Linux线程属性及优先级设置分类
- 利用dd命令对Linux磁盘进行读写能力测试
- cocos2dx ScrollView 测试一 触摸事件优先级和自动调整
- Android SELinux 的认知以及 init 的相关知识,Linux 环境利用这2个模块进行白名单测试 -- 架构分析
- JAVA之旅(十五)——多线程的生产者和消费者,停止线程,守护线程,线程的优先级,setPriority设置优先级,yield临时停止
- java的调度、优先级setPriority、yield、jion和守护线程setDaemon
- linux中使用pthread_kill函数测试线程是否存活