Как говорили другие, lsof
можно использовать для вывода списка всех удаленных файлов, которые все еще находятся на диске из-за открытых файловых дескрипторов. Однако это может быть очень длинный список. Вот команда, которая перечисляет эти файлы, отсортированные по возрастанию в байтах:
sudo lsof -F sn0 | tr -d '\000' | grep deleted | sed 's/^[a-z]*\([0-9]*\)n/\1 /' | sort -n
Может быть более лаконичный способ сделать это, но приведенная выше команда сработала для меня.
Уловка состоит в том, чтобы не использовать bash
для выполнения сложения 1 .
Сначала считайте каждое число в отдельную переменную. Это предполагает, что файлы содержат только номер и никакой другой информации.
a="$(<a.txt)"
b="$(<b.txt)"
Затем используйте калькулятор bc
, чтобы получить результат:
bc <<<"$a + $b"
bc
- это «арифметический язык и калькулятор произвольной точности».
Чтобы сохранить результат в переменной c
:
c="$( bc <<<"$a + $b" )"
Если синтаксис <<<
кажется странным (он называется «здесь-строка» и является расширением Синтаксис оболочки POSIX, поддерживаемый bash
и некоторыми другими оболочками), вместо этого вы можете использовать printf
для отправки дополнения к bc
:
printf '%s + %s\n' "$a" "$b" | bc
и сохранения результата в c
снова:
c="$( printf '%s + %s\n' "$a" "$b" | bc )"
1 Использование bash
для выполнения сложения двух чрезвычайно больших чисел потребует реализации в сценарии bash
, подпрограммы для выполнения арифметики произвольной точности . Это прекрасно выполнимо, но громоздко и ненужно, поскольку каждый Unix поставляется с bc
, который уже предоставляет вам эту услугу относительно простым и доступным способом.
Предполагая, что это десятичные числа, вы можете сделать:
paste -d + a.txt b.txt | bc
Помните, что bc
переносит строки очень длинные числа (более 68 или 69 цифр в зависимости от реализации). В GNU bc
вы можете отключить его, установив для переменной среды BC_LINE_LENGTH
значение 0, например:
paste -d + a.txt b.txt | BC_LINE_LENGTH=0 bc
Как Стефан и Кусалананда сказали , «правда, просто используйте bc», но если вы действительно хотите чтобы использовать bash для сложения, вот отправная точка (только положительные целые числа) - я оставлю это в качестве упражнения для читателя по реализации десятичных и отрицательных чисел:
function arbadd {
addend1=$1
addend2=$2
sum=
bcsum=$(echo $addend1 + $addend2 | BC_LINE_LENGTH=0 bc)
# zero-pad the smallest number
while [ ${#addend1} -lt ${#addend2} ]
do
addend1=0${addend1}
done
while [ ${#addend2} -lt ${#addend1} ]
do
addend2=0${addend2}
done
carry=0
for((index=${#addend1}-1;index >= 0; index--))
do
case ${carry}${addend1:index:1}${addend2:index:1} in
(000) carry=0; sum=0${sum};;
(001|010|100) carry=0; sum=1${sum};;
(002|011|020|101|110) carry=0; sum=2${sum};;
(003|012|021|030|102|111|120) carry=0; sum=3${sum};;
(004|013|022|031|040|103|112|121|130) carry=0; sum=4${sum};;
(005|014|023|032|041|050|104|113|122|131|140) carry=0; sum=5${sum};;
(006|015|024|033|042|051|060|105|114|123|132|141|150) carry=0; sum=6${sum};;
(007|016|025|034|043|052|061|070|106|115|124|133|142|151|160) carry=0; sum=7${sum};;
(008|017|026|035|044|053|062|071|080|107|116|125|134|143|152|161|170) carry=0; sum=8${sum};;
(009|018|027|036|045|054|063|072|081|090|108|117|126|135|144|153|162|171|180) carry=0; sum=9${sum};;
(019|028|037|046|055|064|073|082|091|109|118|127|136|145|154|163|172|181|190) carry=1; sum=0${sum};;
(029|038|047|056|065|074|083|092|119|128|137|146|155|164|173|182|191) carry=1; sum=1${sum};;
(039|048|057|066|075|084|093|129|138|147|156|165|174|183|192) carry=1; sum=2${sum};;
(049|058|067|076|085|094|139|148|157|166|175|184|193) carry=1; sum=3${sum};;
(059|068|077|086|095|149|158|167|176|185|194) carry=1; sum=4${sum};;
(069|078|087|096|159|168|177|186|195) carry=1; sum=5${sum};;
(079|088|097|169|178|187|196) carry=1; sum=6${sum};;
(089|098|179|188|197) carry=1; sum=7${sum};;
(099|189|198) carry=1; sum=8${sum};;
(199) carry=1; sum=9${sum};;
esac
done
if [ $carry -eq 1 ]
then
sum=1${sum}
fi
printf "Sum = %s\n" "$sum"
}
Я оставил bc
сравнение там, но закомментировано для сравнения.