当前位置:  技术问答>linux和unix

请问linux中文件读写放在进程中和线程中性能为什么差别大。修改线程优先级也不行.

    来源: 互联网  发布时间:2015-09-07

    本文导语:  同样的程序,如果在main中直接调用,可以达到50M(和hdparm测试的结果基本一样)。如果在线程中,只有50M/5。 还有有什么工具可以很好的测试linux下硬盘I/O的性能。 谢谢。 线程设置: pthread_t pid; pthread_attr_t* attr...

同样的程序,如果在main中直接调用,可以达到50M(和hdparm测试的结果基本一样)。如果在线程中,只有50M/5。
还有有什么工具可以很好的测试linux下硬盘I/O的性能。
谢谢。



线程设置:
pthread_t pid;
pthread_attr_t* attr;
struct sched_param* param;
param=(struct sched_param*)malloc(sizeof(struct sched_param));
attr=(pthread_attr_t*)malloc(sizeof(pthread_attr_t));
param->sched_priority=99;
pthread_attr_init(attr);
pthread_attr_setscope(attr,PTHREAD_SCOPE_SYSTEM);
pthread_attr_setdetachstate(attr,PTHREAD_CREATE_DETACHED);
pthread_attr_setschedpolicy(attr,SCHED_RR);
pthread_attr_setschedparam(attr,param);
pthread_create(&pid,attr,myProcess,NULL );
//setpriority(PRIO_PROCESS,pid,-20);
//*myProcess(NULL);

全部代码:


// burst.cpp : Defines the entry point for the console application.
//

#include  
#include  
#include  
#include 
#include 
#include 
#include 
#include 
#include  
#include 
#include 

/////////////////////////////////////////////////////////////////////////////
// The one and only application object
#define BUFFERSIZE 1024*1024*10
#define WIBLOCK 30
long startSeconds;
long startMilli;
long finishSeconds;
long finishMilli;
long rate=0;
struct timeb* timeBuffer;
char FName[51][8]={"1.rar","2.rar","3.rar",
  "4.rar","5.rar","6.rar","7.rar",
  "8.rar","9.rar","10.rar","11.rar",
  "12.rar","13.rar","14.rar",
  "15.rar","16.rar","17.rar",
  "18.rar","19.rar","20.rar",
  "21.rar","22.rar","23.rar",
  "24.rar","25.rar","26.rar",
  "27.rar","28.rar","29.rar",
  "30.rar","31.rar","32.rar",
  "33.rar","34.rar","35.rar",
  "36.rar","37.rar","38.rar",
  "39.rar","40.rar","41.rar",
  "42.rar","43.rar","44.rar",
  "45.rar","46.rar","47.rar",
  "48.rar","49.rar","50.rar",
  "51.rar"};
char fileInBuffer[1024*500];
int randSelect[1024*1024];
long randNum=0;
static void *myProcess(void *arg);
int consol();
int threadNum;
int totalTimes=0;
int endFlag;
int g_iThreadNum;
int g_iFileNum;
int g_iBlockSize;
int g_iTotalBlocks;
int g_iThreadReadTimes;

int main()
{
long buffer[32767];
int times;
long k;
long f;
char fBuffer[200];
while(!consol()){};
endFlag=g_iThreadNum*g_iThreadReadTimes;
threadNum=g_iThreadNum;
sprintf(fBuffer,"***********************************************n      Read test in linux!    n         %dM/PER FILE      n***********************************************n",g_iTotalBlocks*g_iBlockSize);
strcat(fileInBuffer,fBuffer);
srand(time((time_t*)NULL));
for(f=0;fmillitm;
for(times=0;timessched_priority=99;
pthread_attr_init(attr);
pthread_attr_setscope(attr,PTHREAD_SCOPE_SYSTEM);
pthread_attr_setdetachstate(attr,PTHREAD_CREATE_DETACHED);
pthread_attr_setschedpolicy(attr,SCHED_RR);
pthread_attr_setschedparam(attr,param);
pthread_create(&pid,attr,myProcess,NULL );
//setpriority(PRIO_PROCESS,pid,-20);
//*myProcess(NULL);
}
while(1){};
}

static void *myProcess(void *arg){

int l_iFileSize;
int handle;
int readTimes;
int currentID;
int currentTimes;
int localEndFlag;
FILE *hfile;
char *Bp;
const char* p;
char fBuffer[WIBLOCK];
//long start, finish;
long ownTimeStartSeconds,ownTimeFinishSeconds,ownTimeStartMilli,ownTimeFinishMilli;
long perFileCost=0;
threadNum--;
currentID=threadNum;
for(readTimes=0;readTimestime;
ownTimeStartMilli=timeBuffer->millitm;
for(l_iFileSize=0;l_iFileSizetime;
ownTimeFinishMilli=timeBuffer->millitm;
ownTimeFinishMilli+=(ownTimeFinishSeconds-ownTimeStartSeconds)*1000;
perFileCost=ownTimeFinishMilli-ownTimeStartMilli;
endFlag--;
localEndFlag=endFlag;
//sprintf(fBuffer,"n Thread %d Filename: %s Readtimes: %d Cost: %ld",currentID,p,currentTimes,perFileCost);
sprintf(fBuffer,"n Thread %d ",currentID);
//myStrCat(fileInBuffer,fBuffer,sizeof(fileInBuffer),sizeof(fBuffer));
strcat(fileInBuffer,fBuffer);
sprintf(fBuffer,"Filename: %s ",p);
strcat(fileInBuffer,fBuffer);
sprintf(fBuffer,"Readtimes: %d ",currentTimes);
strcat(fileInBuffer,fBuffer);
sprintf(fBuffer,"Cost: %ldms ",perFileCost);
strcat(fileInBuffer,fBuffer);
rate+=(g_iTotalBlocks*g_iBlockSize*1024*1000)/(perFileCost);
printf("nThread %d Filename: %s Readtimes: %d Cost: %ld,Average Speed is %ld K/S",currentID,p,currentTimes,perFileCost,((g_iTotalBlocks*g_iBlockSize*1000*1024)/(perFileCost)));
sprintf(fBuffer,"Rate: %ldK/Sn",((g_iTotalBlocks*g_iBlockSize*1000*1024)/(perFileCost)));
strcat(fileInBuffer,fBuffer);
free(Bp);
fclose(hfile);
}

if(!localEndFlag) {
ftime(timeBuffer);
finishSeconds = timeBuffer->time;
finishMilli=timeBuffer->millitm;
finishMilli+=(finishSeconds-startSeconds)*1000;
randNum+=finishMilli-startMilli;
printf("nThread number: %d File number: %d Block size: %dM Total times:%d Cost:%8ld  n",g_iThreadNum,g_iFileNum,g_iBlockSize,g_iThreadNum*g_iThreadReadTimes,randNum);
sprintf(fBuffer,"nThread number: %d File number: %d ",g_iThreadNum,g_iFileNum);
strcat(fileInBuffer,fBuffer);
sprintf(fBuffer,"Block size: %dM Total times: %d Cost: %ldms ",g_iBlockSize,g_iThreadNum*g_iThreadReadTimes,randNum);
strcat(fileInBuffer,fBuffer);
sprintf(fBuffer,"Avrage Rate: %ldK/S n",(rate/((g_iThreadNum)*g_iThreadReadTimes)));
strcat(fileInBuffer,fBuffer);
handle = creat("history.txt", S_IREAD | S_IWRITE); 
write(handle, fileInBuffer, strlen(fileInBuffer)); 
close(handle); 
}
return NULL;
}
int consol()
{
printf("nPlease input Thread number(integer): ");
scanf("%d",&g_iThreadNum);
printf("nPlease input fileNum(integer): ");
scanf("%d",&g_iFileNum);
if ((g_iFileNum)>50){ printf("n File number must 

    
 
 

您可能感兴趣的文章:

  • 请问:进程创建的线程是怎样运行的啊,线程的处理函数运行完了,线程就退出了吗?
  • 请问Linux核心支持多线程吗?开发库有线程库吗?线程好用吗?(稳定?)
  • 请问,在一个进程中创建多线程时如何能避免不同的线程获得同一个线程标识
  • 请问在java多线程中,是只有run(){}内的代码运行在一个新线程下呢?还是这个类中的代码都运行在一个新线程下?
  • 请问在多线程得程序中,函数内的局部变量是否线程安全的
  • 请问Linux下线程开销为什么这么大?一个线程要占用近10M内存
  • 请问在单进程,多线程程序里,线程间使用IPC的信号量来同步,能行吗?
  • 请问对于多线程程序应该如何测试线程的切换开销呢
  • 请问线程的运行顺序是怎样的
  • 请问线程编成的问题
  • 请问什么叫线程安全?
  • 请问一个线程的优先级增加能使线程停止执行吗?
  • 请问大侠们,线程中sleep到底行不行?? 希望是线程sleep的终结帖!!
  • 请问:linux下的子进程与线程的区别
  • 请问:如何优雅的结束一个正在等待锁的线程?
  • 请问前辈,线程和进程有什么区别啊?
  • 请问关于多线程SOCKET的问题
  • 请问调用notify后被选中线程的wait是立刻返回,还是等到调用notify的线程退出synchronized块后再返回?
  • 请问单线程异步机制的优势在哪里?
  • 请问在solaris下可以取得一个线程的ID号吗?
  • 请问如何设置驱动程序和应用程序的启动顺序和优先级呢?
  • 请问在Linux下怎么修改当前线程的优先级?
  • 【linux菜鸟第一帖】:请问多线程开发,为何不能设置多个线程的优先级问题?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 请问JAVA如何读写注册表
  • 请问,FIFO的读写是否有字节数限制,PIPE_BUF如何使用?
  • 请问如何用shell来读写文本文件呢?
  • 请问:java语言能读写注册表吗?多谢多谢,
  • 请问unix下修改文件和文件夹读写权限的问题
  • 请问下如何知道进程有没有从内存读写数据?
  • 请问怎样才能解决读写大文件时文件不丢失问题
  • 请问在嵌入式linux应用中,串口操作需要包括什么,h文件,以及读写命令是什么?谢谢
  • 请问如何读写共享内存!(麻烦大侠们了)
  • 请问:我知道路由器的telnet密码,但忘记了enable 密码,请问如何是好?
  • 请问那里有SYBASE的jbdb 2.0下载;jspsmartupload可以直接将文件上传到数据库,请问如何使用
  • 请问最新的reahat9.0是基于什么核心的?2.4?2.6?请问那里能下载?
  • 请问:请问哪里有关于linux基本操作命令讲解的资料下载,最好是幻灯片格式的.
  • 请问,我试图用#admintool&图形工具命令来安装sun workshop5.0,为什么进入的却是用户管理界面?请问具体该如何在solaris下安装应用软件
  • 请问在Redhat 9里,我从登录就是图形介面,请问如何在图形介面内进入命令行方式呢,谢谢
  • 请问玩过SOLARIS的高手门,在不正常关机后,就不能启动到windows公用桌面了,只能在命令提示模式下了,请问怎么解决这个问题啊?急~!~!
  • 请问:我在redhat下装了bochs-2.2.1-1.rpm,.装了后,想设置一下,但找不到bochsrc.fda.bxrc,请问这个文件在哪个曰录下啊。
  • 请问:在配置Qt时,很多文档都说在.profile,.login里加东西,但是我好像没有发现有这两个文件上,请问这些文件在哪个目录下啊
  • 请问:在GCC里的C程序里的变量的声明是不是只能在前面,而且相同类型的变量的声明只能放在一起?如果不是,请问怎么样可以解决这个问题.
  • 请问各位大虾,小弟今天开始学jsp了,这学期我们有java课,所以已经下载了jdk(好象是1.2),请问我的98环境怎么配置jsp环境呀?我的jdk可以运行.java程序,别的我就不知道了....谢谢!
  • 主机是WIN2000,我用的是LUNIX,请问是否可以共享上网? 如果可以请问如何设置? 500分答谢,龟儿食言!
  • 请问linux下GUI开发的问题!
  • 请问出现fstab文件丢失该怎么修复呀?
  • 请问这个方法如何调用?
  • 请问一个奇怪的问题!
  • 请问在网页中打开的新窗口,如何让其居中。
  • 请问我该学什么了
  • 请问安装zhcon,cxterm问题
  • 非常急! 请问daemontools 在red hat 9下的安装问题? 在线等待


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3