我有一个C shell脚本,它执行以下操作:
#!/bin/csh
gcc example.c -o ex
gcc combine.c -o combine
ex file1 r1 <-- 1
ex file2 r2 <-- 2
ex file3 r3 <-- 3
#... many more like the above
combine r1 r2 r3 final
\rm r1 r2 r3
有没有办法让1
,2
和3
行在parallel中运行,而不是一个接一个地运行?
发布于 2010-05-08 03:13:52
将其转换为具有适当依赖项的Makefile。然后,您可以使用make -j
使所有可能的操作都可以并行运行。
请注意,Makefile中的所有缩进都必须是制表符。选项卡显示了要运行的命令所在的Make。
还要注意,这个Makefile现在正在使用GNU Make扩展(通配符和subst函数)。
它可能看起来像这样:
export PATH := .:${PATH}
FILES=$(wildcard file*)
RFILES=$(subst file,r,${FILES})
final: combine ${RFILES}
combine ${RFILES} final
rm ${RFILES}
ex: example.c
combine: combine.c
r%: file% ex
ex $< $@
发布于 2010-05-08 03:24:58
在狂欢中我会这么做;
ex file1 r1 &
ex file2 r2 &
ex file3 r3 &
wait
... continue with script...
然后把它们生出来并行运行。你可以用check out this SO thread来看另一个例子。
发布于 2010-05-08 03:27:15
#!/bin/bash
gcc example.c -o ex
gcc combine.c -o combine
# Call 'ex' 3 times in "parallel"
for i in {1..3}; do
ex file${i} r${i} &
done
#Wait for all background processes to finish
wait
# Combine & remove
combine r1 r2 r3 final
rm r1 r2 r3
我稍微修改了代码,使用了大括号扩展{1..3}
,而不是硬编码数字,因为我刚刚意识到你说的文件比3多得多。大括号扩展通过将大括号内的'3‘替换为你需要的任何数字,使得扩展到更大的数字变得微不足道。
https://stackoverflow.com/questions/2791069
复制相似问题