如何使用变量在bash中指示文件描述符?

时间:2011-11-28 12:36:36

标签: bash io exec file-descriptor

我想使用bash变量来指示文件描述符,如下所示:

id=6
file=a
exec $id<>$file

但用法不对:

-bash: exec: 6: not found

那么,如何使用变量在exec命令中指示文件描述符?

3 个答案:

答案 0 :(得分:18)

接受的答案是正确的,但是as of bash 4.1,您可以使用自动文件描述符分配,在这种情况下,您不需要eval

file=a
exec {id}<>"$file"

然后你可以像这样使用它:

echo  test >&${id}

或:

fsck -v -f -C ${id} /dev/something

答案 1 :(得分:14)

您必须使用eval并将整个表达式放在引号中。

eval "exec $id<>$file"

每次要使用$id时都这样做。

答案 2 :(得分:0)

我发现tobias.pal的答案中的讨论非常有趣:https://stackoverflow.com/a/32689974/1184842

for (( FD=3 ; FD < 100 ; FD++ )) ; do exec {FD}> file.$FD ; echo $FD >&${FD}; done

这将不起作用,因为exec {FD}> file.${FD}在$ FD的所有值上都是相同的描述符,对吗? (Denio Mariz)

我通过使用Drew Chapin所述的数组解决了这个问题:

#!/bin/bash
# global variables for temp file handling
declare -a TEMPORARY_FILES_WRITE;
declare -a TEMPORARY_FILES_READ;

function createTempFile() {
    local usecase="$1"
    local id="$2"
    local tmpfile=$(mktemp)  # Create a temporal file in the default temporal folder of the system

    # Lets do some magic for the tmpfile to be removed when this script ends, even if it crashes
    exec {TEMPORARY_FILES_WRITE[$id]}>"$tmpfile"
    exec {TEMPORARY_FILES_READ[$id]}<"$tmpfile"
    rm "$tmpfile"  # Delete the file, but file descriptors keep available for this script
}    

for (( FD=3 ; FD < 100 ; FD++ )) ; do 
    TEMP_FILE_COUNTER=$((TEMP_FILE_COUNTER + 1))
    createTempFile "Iteration $FD" $FD ;
    echo $FD >&${TEMPORARY_FILES_WRITE[$FD] ;
done

example=$(cat <&${TEMPORARY_FILES_READ[50]})
echo $example

这将输出50。