日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

python多线程框架_基于python和bash的多线程任务框架 不要让cpu闲着了

發(fā)布時間:2025/3/11 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python多线程框架_基于python和bash的多线程任务框架 不要让cpu闲着了 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

[Bash shell] 純文本查看 復(fù)制代碼#! /bin/bash

##########################################################################################################

#part1:defile your job(第一部分,定義單核任務(wù),需要根據(jù)你的實用任務(wù)改動)

date >>time

Nproc=40 #prcocess used here (要用的線程數(shù))

ls *ligand.mol2 >list #list of jobs (所有的任務(wù)放到一個list里面)

Njob=$(echo $(cat list|wc -l)+1|bc) #total jobs+1 (統(tǒng)計總?cè)蝿?wù)數(shù)目)

function jobrun #define your job (定義一個函數(shù)任務(wù))

{

j=$(cat list|sed -n "$1"p|cut -c 1-4) #$1 is a parameter for jobid ($1作為函數(shù)輸入 即任務(wù)號 這里首先要找到任務(wù)號對應(yīng)的分子)

prepare_dpf42.py -l $j"_ligand.pdbqt" -r $j"_receptor.pdbqt" -o tmp2 #(為了簡單期間這里沒有寫如何計算格子 如何計算格點文件 這里是從準備dpf文件開始)

autodock4 -p $j.dpf -l $j.dlg #(對接)

}

##############################################################################################################

#part2:mutiple process framwork (第二部分,多線程框架,可以不用懂不用改動)

PID=() #PID is an array to store the pid of your job (PID 用于儲存每個線程的pid)

for ((i=1;i

do

for ((Ijob=0; Ijob

do

if [[ $i -ge $Njob ]]; #(如果任務(wù)都完成了就退出循環(huán))

then

break;

fi

if [[ ! "${PID[Ijob]}" ]] || ! kill -0 ${PID[Ijob]} 2> /dev/null; then #(如果線程沒有被占用)

echo start $i with $Ijob

jobrun $i $Ijob& #(用Ijob線程執(zhí)行任務(wù)i)

PID[Ijob]=$! #(任務(wù)完成 釋放線程Ijob)

i=$((i+1))

fi

done

##########################################################################################

wait #(等所有線程都空閑下來)

done

echo job finished!

date >>time

總結(jié)

以上是生活随笔為你收集整理的python多线程框架_基于python和bash的多线程任务框架 不要让cpu闲着了的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。