sleep(1)で標準出力に栓をする

Thu Nov 6 23:11:12 JST 2014 (modified: Tue Sep 19 21:55:56 JST 2017)
views: 1648, keywords:コマンド,CLI,sleep,字が・・・字が漏れちゃう・・・,シェル芸,頭の中だだ漏らし この記事は最終更新日が6年以上前のものです。

小ネタです。私の手抜きbashボットでも活躍中のsleepコマンドのアホな使い方です。

あるソートのプログラムが出力直前に使っているメモリの量を調べるという、超ニッチな作業がありました。ニッチですが・・・確かにあったんですよ奥さん。

んで、楽な方法をいろいろ探しているうちに、「出力する出口を塞いでしまえば出力直前でプログラムが止まるんじゃね?」という考えに至りました。

readとかも試したのですが、sleep(1)がこの場合は一番手軽でした。例はyesの出力を止める例ですが、確かに指定した時間だけ止まります。1億秒待つのは大変でした。

$ yes 高須クリニック | sleep 100000000
   ###しばらく放置の後、別の端末で見てみる。###
   uedambp:RESULT ueda$ ps u 
   USER PID %CPU %MEM VSZ RSS TT STAT STARTED TIME COMMAND
   ueda 97775 0.0 0.0 2442992 548 s005 S+ 10:55PM 0:00.00 sleep 100000000
   ueda 97774 0.0 0.0 2432752 536 s005 S+ 10:55PM 0:00.01 yes ?M^X?\\240M^H?M^B??M^C??M^CM^K?
   ↑イター!!!
   (以下略)

ちなみにsleepは読んだ入力を標準出力に出す訳ではないので、1億秒後には何も出てきません。

ということで、次のように、作ったプログラム(input_string)が字をお漏らしする直前に使っているメモリの量が分かったのでした。

$ seq 1 10000000 | ./input_string | sleep 10000000
   $ ps u | awk 'NR==1 || /input_string/' | grep -v awk
    (略) VSZ RSS (略) COMMAND
    (略) 6385120 3942652 (略) ./input_string

めでたしめでたし。しっかし、ニッチだ・・・。そして別のコマンドが出したい出したいと言っているのにそれを止めるsleep(1)に、ものすごいS属性があるような気がして妄想が止まらないのでした。

アホくさいので寝る。

ノート   このエントリーをはてなブックマークに追加 
 

prev:Structure and Interpretation of Computer Programs読書会24回目メモ書き next:背景のややこしい図に矢印を引く

やり散らかし一覧

記事いろいろ