gpt4 book ai didi

bash - 如何防止 BASH_REMATCH 泄漏出函数?

转载 作者:行者123 更新时间:2023-12-04 02:11:29 25 4
gpt4 key购买 nike

我想使用 bash 运算符 +~ 首先拆分一个字符串,然后再次检查生成的字符串。当我尝试这个时,如果发现 BASH_REMATCH 的元素被第二次使用覆盖,所以 mother-function 在第二次使用时失败。

以下面构造的例子为例:

#!/bin/bash

inputline="abc123ABC123abc,xyz890XYZ890xyz"

checkABC ()
{
local teststring="$1"
local pattern="([^,]+),(.*)"

if [[ $teststring =~ $pattern ]]; then
echo "${BASH_REMATCH[1]}; ${BASH_REMATCH[2]}"
checkNum ${BASH_REMATCH[1]}
checkNum ${BASH_REMATCH[2]}
fi

}

checkNum ()
{
if [[ $1 =~ [a-z]+([0-9]+)[A-Z]+([0-9]+)[a-z]+ ]]; then
echo "${BASH_REMATCH[1]}; ${BASH_REMATCH[2]}"
fi
}

set -x
checkABC $inputline

这将给出以下输出,我们可以看到,${BASH_REMATCH[2]} 是如何被函数 checkNum 覆盖的。

$ bash ./leaking.sh
+ checkABC abc123ABC123abc,xyz890XYZ890xyz
+ local teststring=abc123ABC123abc,xyz890XYZ890xyz
+ local 'pattern=([^,]+),(.*)'
+ [[ abc123ABC123abc,xyz890XYZ890xyz =~ ([^,]+),(.*) ]]
+ echo 'abc123ABC123abc; xyz890XYZ890xyz'
abc123ABC123abc; xyz890XYZ890xyz
+ checkNum abc123ABC123abc
+ [[ abc123ABC123abc =~ [a-z]+([0-9]+)[A-Z]+([0-9]+)[a-z]+ ]]
+ echo '123; 123'
123; 123
+ checkNum 123
+ [[ 123 =~ [a-z]+([0-9]+)[A-Z]+([0-9]+)[a-z]+ ]]

我知道我可以通过将重新匹配的结果复制到另一个数组来防止这种情况,我可以在本地处理它并在其上应用 checkNum(请参见下面的示例)。这是明智的做法吗?还是有更好的方法来防止 BASH_REMATCH 从函数中泄漏出来?

这段代码

#!/bin/bash

inputline="abc123ABC123abc,xyz890XYZ890xyz"

checkABC ()
{
local teststring="$1"
local pattern="([^,]+),(.*)"
local -a storeRematch

if [[ $teststring =~ $pattern ]]; then
storeRematch=("${BASH_REMATCH[@]}")
echo "${storeRematch[1]}; ${storeRematch[2]}"
checkNum ${storeRematch[1]}
checkNum ${storeRematch[2]}
fi

}

checkNum ()
{
if [[ $1 =~ [a-z]+([0-9]+)[A-Z]+([0-9]+)[a-z]+ ]]; then
echo "${BASH_REMATCH[1]}; ${BASH_REMATCH[2]}"
fi
}

set -x
checkABC $inputline

像我希望的那样执行:

bash ./notleaking.sh
+ checkABC abc123ABC123abc,xyz890XYZ890xyz
+ local teststring=abc123ABC123abc,xyz890XYZ890xyz
+ local 'pattern=([^,]+),(.*)'
+ local -a storeRematch
+ [[ abc123ABC123abc,xyz890XYZ890xyz =~ ([^,]+),(.*) ]]
+ storeRematch=("${BASH_REMATCH[@]}")
+ echo 'abc123ABC123abc; xyz890XYZ890xyz'
abc123ABC123abc; xyz890XYZ890xyz
+ checkNum abc123ABC123abc
+ [[ abc123ABC123abc =~ [a-z]+([0-9]+)[A-Z]+([0-9]+)[a-z]+ ]]
+ echo '123; 123'
123; 123
+ checkNum xyz890XYZ890xyz
+ [[ xyz890XYZ890xyz =~ [a-z]+([0-9]+)[A-Z]+([0-9]+)[a-z]+ ]]
+ echo '890; 890'
890; 890

最佳答案

有点 hack,但由于它仅在当前 shell 中是本地的,因此您可以在函数中运行子 shell。

checkNum ()
{
(
if [[ $1 =~ [a-z]+([0-9]+)[A-Z]+([0-9]+)[a-z]+ ]]; then
echo "${BASH_REMATCH[1]}; ${BASH_REMATCH[2]}"
fi
)
}

(
checkNum ${BASH_REMATCH[1]}
checkNum ${BASH_REMATCH[2]}
)

这将防止 BASH_REMATCH 对两个函数都是全局的。

除此之外,我认为将它分配给另一个数组是您将获得的最好结果(实际上比这个更好,因为它不会打开新的进程/子 shell)。

关于bash - 如何防止 BASH_REMATCH 泄漏出函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37674871/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com