【perl語(yǔ)言】利用threads實(shí)現(xiàn)多線程運(yùn)算

代碼如下

#!/usr/bin/env perl 
use strict;
use threads;
use Thread::Semaphore;

my $trait = $ARGV[0];
my $NumOfTrait = 0;
my $thread;
my $max_cpu = 28;
my $semaphore = new Thread::Semaphore($max_cpu);
my (@line, @line, %traitDict, $i);

open REF, "taxa_".$trait.".txt";
while(<REF>){
  chomp;
  @line = split /\t/;
  $traitDict{$line[0]} = $line[1];
  $NumOfTrait ++;
}

# check num of trait <> 28
for($i=1; $i<=$NumOfTrait; $i++){
  $semaphore->down();
  $thread = threads->new(\&run_gemma, $trait, $i, $traitDict{$i});
  $thread->detach();
}
#
&waitquit();

# functions 
sub waitquit{
  my ($i);
  for($i=0;$i<$max_cpu;$i++){
    $semaphore->down();
  }
  $semaphore->up($max_cpu);
}

sub run_gemma{
  my($phe, $col, $name) = @_;
  system("bash ../02.gemma.sh Bna171_".$phe." ".$col." ".$name);
  print "[INFO] $name is done.\n";
  $semaphore->up();
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容