UNIXプログラミング質問すれ Part8 at TECH
[2ch|▼Menu]
1:970
06/05/18 18:56:16
UNIXおよびUNIX clone環境一般のプログラミングに関する質問スレッド

前スレ
Part7 スレリンク(tech板)
Part6 スレリンク(tech板)
Part5 スレリンク(tech板)
Part4 スレリンク(tech板)
Part3 スレリンク(tech板)
Part2 スレリンク(tech板)
Part1 URLリンク(pc2.2ch.net)

Part3のミラー
URLリンク(makimo.to)
Part2のミラー
URLリンク(makimo.to)


2:970
06/05/18 18:58:40
関連スレ
Cygwin使っている人いますか? その14 (UNIX板)
スレリンク(unix板)
Cygwin使っている人いますか? 3 (Windows板)
スレリンク(win板)
ネットワークプログラミング相談室 Port13
スレリンク(tech板)
マルチスレッドプログラミング相談室 その3
スレリンク(tech板)
プログラミング質問すれ Part1(Unix板)
スレリンク(unix板)
XWindowプログラミング 質問箱
スレリンク(tech板)

関連板
URLリンク(pc8.2ch.net)
URLリンク(pc8.2ch.net)

3:970
06/05/18 19:00:56
【POSiX】
The Open Group Base Specifications Issue 6
IEEE Std 1003.1, 2004 Edition
URLリンク(www.opengroup.org)

【必読書】
Advanced Programming in the UNIX(R) Environment
URLリンク(www.amazon.com)

Unix Network Programming
Vol. 1: The Sockets Networking API, Third Edition
URLリンク(www.amazon.com)

UNIX Network Programming
Volume 2: Interprocess Communications (2nd Edition)
URLリンク(www.amazon.com)

man on www
URLリンク(www.linux.or.jp)

GNU Make 日本語リファレンス
URLリンク(www.ecoop.net)

Unix Programming Frequently Asked Questions 日本語訳
URLリンク(www.adl.nii.ac.jp)

4:デフォルトの名無しさん
06/05/18 19:57:54
>>1


5:デフォルトの名無しさん
06/05/18 20:03:08
萌え

6:デフォルトの名無しさん
06/05/18 22:03:46
相変わらず質問を強要するスレだな

7:デフォルトの名無しさん
06/05/18 22:08:01
いいから質問すれ。

8:sage
06/05/19 01:56:58
C10K Problemの話題はここでいいですか?
URLリンク(www.kegel.com)

9:デフォルトの名無しさん
06/05/19 02:04:13
そのページに「まずこれを読め」と書いてあるのを読んでからどうぞ。

10:デフォルトの名無しさん
06/05/23 10:04:49
俺的おすすめ入門書

ふつうのLinuxプログラミング Linuxの仕組みから学べるgccプログラミングの王道
URLリンク(www.amazon.co.jp)

Linuxプログラミング―例題で学ぶUNIXプログラミング環境のすべて
URLリンク(www.amazon.co.jp)

11:デフォルトの名無しさん
06/05/26 01:07:40
共有ライブラリ形態のlog出力ライブラリを作っていたのですが
ついつい、排他処理をさぼっていました。同期しない排他処理をするなら
spin_lock()
write_log()
spin_unlock()
こんな感じでOKですよね?

12:デフォルトの名無しさん
06/05/26 06:33:35
syslog

13:デフォルトの名無しさん
06/05/27 01:22:54
syslog遅くてだめです。プロセス3つに対して共通のファイルにログを
吐かせたいんですけどこうゆう場合の実装ってどうすればいいのでしょうか?

14:デフォルトの名無しさん
06/05/27 02:10:18
syslogが遅いってどんな環境なんだか

15:デフォルトの名無しさん
06/05/27 02:15:45
URLリンク(tnetio.sourceforge.jp)
ここでかかれている問題と、案件上の問題で
ログの誤差は1000時間で1msec以内なので実装するしかないのですよ

16:デフォルトの名無しさん
06/05/27 07:23:00
Linuxのことは全然知らんが、spin_lock()ってカーネルの外で使えんの?

17:デフォルトの名無しさん
06/05/27 07:34:28
大事なログってハングアップして消えたら困るだろ?
だからログメッセージを記録する度に fsync() するんだよ。
遅いのは我慢汁。

18:デフォルトの名無しさん
06/05/27 07:44:50
>>15
とても参考になりました。
ありがとう。

19:デフォルトの名無しさん
06/05/27 09:00:34
いや、fsyncするから遅いとは言え、ボトルネックを解消
するためにsyslogを再発明ってDJBじゃあるまいし・・・
それにそのシステム、遅延は許されないけどログのロスト
は許されるの? だったらsyslogからネットワークに出せば
いいのでは。

あとlinuxのsyslog.confのmanを見ると
URLリンク(www.linux.or.jp)
「マイナス記号 ``-'' を接頭すると、記録の際のファイルシステム
バッファのフラッシュ動作を抑制する。」とあるがこれじゃだめなの?

20:デフォルトの名無しさん
06/05/27 09:10:09
同期しない=spin_lock()
ってのが意味分からないんだが。

CPUをyieldしたくないって意味で言っているの?

21:デフォルトの名無しさん
06/05/27 09:25:45
>ログの誤差は1000時間で1msec以内なので実装するしかないのですよ

なんかよくわからないけど、ものすごいこと言ってる気がする。

22:デフォルトの名無しさん
06/05/27 09:49:23
>>19
URLリンク(tnetio.sourceforge.jp)

syslogd は、ログサーバにログメッセージを送る際、相手に時間を送りません。
syslogd のソースを解析した所、個人的には、ちょっと信じられないのが正直な感想なのですが、
syslogd が、別のログサーバに UDP を通じてログメッセージを送る際、
syslog() 呼び出しの時に埋め込んだ日付時刻を送信していない事が分かりました。

 

UDP で待受ける syslogd は、受け取ったメッセージ内部に時間情報が存在しない場合、
自分の時間を書き込みます。従って、 *syslog() 発生時の時間ではなく、
ログサーバの syslogd が受け取った時の時間* が書き込まれますので、
もし、サーバー間で時間がズレている場合、そのズレが直接影響しますし、
また、UDP 送信のタイムラグによってもズレます。


23:デフォルトの名無しさん
06/05/27 09:58:51
1msecのズレがあるかどうかはどうやって測定して検収する気なんだろう。
syslog()を呼んでから時刻情報を付加してI/Oシステムコールを
呼び出すまでの間にプロセスのスイッチや他の処理のせいで
1msecの遅延が出たらどうするんだろう。
それ絶対仕様書いた奴が馬鹿だよね。真面目に実装しようとする奴も馬鹿だけど。

24:デフォルトの名無しさん
06/05/27 10:06:13
Linuxのsyslogdが全て悪いってことでしょ?
全てのディストリビューションで同じものを使っているのかどうかも知らないけど、
syslogdを変更するとか、syslogdのふりをして>>22の問題点を解消した
パケットを自分で投げるとか、syslogdのつける時刻に頼るのをやめて
時刻情報を自分で取得してメッセージに含ませるとか、
やりようはあるんじゃないの。

もっとも、自分で再発明するのを含めて何をどうやっても

> ログの誤差は1000時間で1msec以内なので実装するしかないのですよ

というのは(いまいち意味不明ではあるが)保証するのは難しいと思うけど。



25:デフォルトの名無しさん
06/05/27 10:18:18
GPS時刻同期型のNTPサーバから直接シリアルで同期を取っているので
大丈夫なのですが
問題は、syslog() 発生時の時間ではなく ログサーバの syslogd が受け取った時の時間
になってしまうことが嫌なんですよ。


26:デフォルトの名無しさん
06/05/27 10:22:07
>>25
問題はそこじゃないだろ。悪いこと言わないから別の人に代わってもらった方がいいよ。


27:デフォルトの名無しさん
06/05/27 10:23:29
別に無理にsyslogを使わなくても、最初に言ってる>>11のようにすりゃいいんじゃないの?
spin_lock()というのが妥当かどうかは別として。

28:デフォルトの名無しさん
06/05/27 10:26:36
ふつうプリンタにログを直書きだよね

29:デフォルトの名無しさん
06/05/27 10:39:07
write_log(を囲むクリティカルセクション)が1msecで終わる保証はあるのかとか、
根本的な問題としてはログを書くということが必要になってから>>11
クリティカルセクションに入るまでの間に割込み等があったら
ロギング機構がつける時刻がいくら完璧正確でも>>15の要求は満たせないんだがとか、
そのへんはいいんかいな。


30:デフォルトの名無しさん
06/05/27 10:39:52
>ログの誤差は1000時間で1msec以内なので実装するしかないのですよ
ひどい仕様だな

31:デフォルトの名無しさん
06/05/27 10:53:01
>>24
> Linuxのsyslogdが全て悪いってことでしょ?

違うだろ。

> syslogdのつける時刻に頼るのをやめて
> 時刻情報を自分で取得してメッセージに含ませるとか、

程度の知恵もないヤツが悪いだけ。

今回の場合は、syslogで十分かどうか、仕様も曖昧だから良く分からないけれど。

32:デフォルトの名無しさん
06/05/27 10:54:19
>>30
というか日本語として意味が成立してない。

33:デフォルトの名無しさん
06/05/27 10:55:16
>>31
>> syslogdのつける時刻に頼るのをやめて
>> 時刻情報を自分で取得してメッセージに含ませるとか、
>
>程度の知恵もないヤツが悪いだけ。

いや、 syslogd は自分で付けた時刻情報も取り去ってリモートに送信すると書いてあるが

34:デフォルトの名無しさん
06/05/27 12:17:52
( ゚д゚)ポカーン

35:デフォルトの名無しさん
06/05/27 12:18:21
国語力のないアホがやってまいりました


36:デフォルトの名無しさん
06/05/27 12:52:23
$ logger -p local0.notice -t 'ボクちゃん' '今日は僕の誕生日です。'

メッセージが全文削除されるのですが何故でしょうか?
syslogdの仕業ですか?

37:デフォルトの名無しさん
06/05/27 12:54:03
RTM

38:デフォルトの名無しさん
06/05/27 14:39:27
汎用OSじゃ無理ってことでOK?

39:デフォルトの名無しさん
06/05/29 12:46:55
いいえ

40:デフォルトの名無しさん
06/06/02 08:29:17
もっとも高速なRAMへのアクセス方法を教えてください

41:デフォルトの名無しさん
06/06/02 08:45:13
キャッシュに載る大きさだけ使う

42:デフォルトの名無しさん
06/06/02 08:58:13
>>41
自分のプロセスだけでキャッシュを占められるわけじゃないから、
正解は「可能な限りメモリ使用量を減らす」だな。

43:デフォルトの名無しさん
06/06/02 11:03:15
>>42
どういう想定してるんだか知らないが、他プロセスの存在や種類を任意とすると
コンテクストスイッチしたらキャッシュの中身は入れ替わらざるを
得ないだろうから>>41で正解。
むしろ>>42は不正解。メモリ使用量ではなく局所性に着目すべき。


44:デフォルトの名無しさん
06/06/02 23:54:25
gcc -Os

45:デフォルトの名無しさん
06/06/03 12:38:55
ファイルを標準入力にリダイレクトしたあとキーボードからの入力も受け付けたいのですが、openシステムコールでキーボードを開いたりって出来ませんか?
ちなみに最初からリダイレクトせずにファイルのほうをopenして読むというのは意図から外れてしまうのであしからず
どなたかご存知でしたらよろしくお願いします

46:45
06/06/03 12:40:18
書き忘れていましたが環境はWindows2000をホストとしてVMWare Player上で動かしているVine Linux 3.2です

47:デフォルトの名無しさん
06/06/03 12:48:48
/dev/tty

48:デフォルトの名無しさん
06/06/03 13:02:19
>>45
ls | less のlessは、やっているよな。>>47の方法で。

49:デフォルトの名無しさん
06/06/03 16:15:38
おお、、これはよさそうなものが
>>47,48 さんありがとうございました

50:デフォルトの名無しさん
06/06/13 19:59:12
MTAにpostfixを使っている環境で、C言語のプログラムでメールを受信したいです。

はじめ、スプールファイルを直接読んで処理しようと思ったのですが、エンコード
やら、文字コード変換やら色々とややこしく、簡単な方法を模索しています。

POP3のライブラリとかあればと思ったのですが、ググッてみても出てきませんでした。
何かよいライブラリがありましたら、おしえてください。


51:デフォルトの名無しさん
06/06/13 20:03:12
何やりたいのかよくわからんけど、簡単にやるなら C でわなく perl あたりだと思う今日この頃。

52:50
06/06/13 20:47:20
訳あってC言語なんですが、やりたいことはメールの内容を解読して、DB(ポスグレ)に
書き出すというプログラムです。
常に起動していて、スプールファイルにデータが書き込まれたときに処理を行います。

文字コード変換は、iconv()という関数で出来るらしいという情報は得ましたが、
デコード(ISO-2022JP/BASE64)処理ができる関数というのがまだみつかっていません。

POP3のライブラリとかあれば、自動的にやってくれると思っているんですが、
ないでしょうか・・・

53:デフォルトの名無しさん
06/06/13 22:37:43
base64くらい簡単なんだから取り敢えず自分で書いちゃえば?

54:デフォルトの名無しさん
06/06/13 23:34:47
このプログラムを高速化する方法を教えてください。よろしくお願いします。
#include<stdio.h>
main()
{
int i, j;
i=0;
while( i < 100){
j=2;
while( j < i){

if( i % j == 0)
break;
j++;
}
if( i == j)
printf("%d\n", i);
i++;
}
}



55:デフォルトの名無しさん
06/06/14 01:00:00
#include <stdio.h>
int main()
{
printf("2\n3\n5\n7\n11\n13\n17\n19\n23\n29\n31\n37\n41\n43\n47\n53\n59\n61\n67\n71\n73\n79\n83\n89\n97\n");
exit(0);
}

56:デフォルトの名無しさん
06/06/14 01:03:56
>>52
metamailのソースを窃盗しろ。

57:デフォルトの名無しさん
06/06/14 02:05:28
>>52
あえてbase64のためだけにglib

58:デフォルトの名無しさん
06/06/15 03:08:55
Segmentation faultなどで、プログラムが停止すると、
コアが吐かれますが、あれはどのように活用すればよいのでしょうか?


59:デフォルトの名無しさん
06/06/15 03:14:56
乱数表

圧縮率評価用サンプル


60:デフォルトの名無しさん
06/06/15 03:45:48
コアってのは、プロセスが死んだときのそのプロセスが使っていたメモリの内容。
デバッガに、死んだプログラムの実行イメージとともに与えることで、プロセス
死亡時の状況
・どういう経路でどの関数の何行目に到達して死んだのか
・そのときの各変数はどんな値だったか
が再現でき、死因を調べるのに使える。

61:デフォルトの名無しさん
06/06/15 08:06:02
素人でも出来ますか?

62:デフォルトの名無しさん
06/06/15 08:44:56
Unix系なら最低限adb程度のデバッガがある。
adbがあるなら、coreのあるディレクトリでadb <実行モジュール> として起動、
$c を入力すればスタック履歴が出るのでどの関数から呼ばれたどの関数から吐いたコアか判る(事も多い)。
但し、実行モジュールのシンボルが剥がされていると関数名が出ない。
#詳しくは手元のデバッガの使い方を調べてくれ。

63:デフォルトの名無しさん
06/06/15 09:25:43
>>60
> コアってのは、

コアダンプってのは、


64:デフォルトの名無しさん
06/06/15 09:46:21
>>60
> コアってのは、

ヨーグルト

65:デフォルトの名無しさん
06/06/15 12:06:43
>>63(笑)

66:デフォルトの名無しさん
06/06/15 12:21:32
pascalの文法には、変数名とか関数名の非終端記号があるらしんだけど
これはすべて名前(識別子)であって文法を簡単にするものであると。

原始プログラム中のその名前をみただけではどの名前であるか
判別できない。これの解決策はなにですか?


67:デフォルトの名無しさん
06/06/15 12:25:45
>>66
Ruby

68:デフォルトの名無しさん
06/06/15 13:57:12
>>62
Linuxとか*BSDならgdbもあるだろうしな。

69:デフォルトの名無しさん
06/06/15 14:05:32
>>66
冷たいようだが「宿題スレに行け」。

70:デフォルトの名無しさん
06/06/15 16:33:56
UNIX なら dbx!!

71:デフォルトの名無しさん
06/06/15 18:35:45
Linux上でブロードキャストメッセージを受信するプログラムを作成している者なのですが、
PCなどから送信したブロードキャストメッセージの信号にのってるMACアドレスを取得したく考えてます。

recvfromを使用しても、UDPデータ部しか見れなくて、困っているんですが、この場合、
RAWソケットを使用しないと、見れないものなのでしょうか?
また、RAWソケットを使用して、特定のポートのみをチェックすることって可能なのでしょうか?



72:デフォルトの名無しさん
06/06/15 18:52:15
>>71
IPレイヤから物理層レイヤのヘッダを把握してはいけません。
そもそもloやtunやpppやslipだったりしたらmacaddressなんて存在しないが?

73:71
06/06/15 19:06:42
>>72
そのとおりですね。。。
想定として、LAN内のPCから受信するUDPメッセージのみを意識していたので、この書き方になってました。
もう少し、書くべきでした。

UDPメッセージの送信元MACアドレスを引く場合には、何か方法があるんでしょうか?
(MACアドレスを使用して認証みたいなことをしたいんで。。。)

74:デフォルトの名無しさん
06/06/15 19:53:12
linuxならPF_PACKETとか。libpcapのソース嫁

75:デフォルトの名無しさん
06/06/16 00:09:51
>>74
まあraw socketってことだよね。

MACアドレスは、NICによっては簡単に詐称する事できるので、
まじ認証をやらないように。

76:50
06/06/16 09:43:06
みなさん、色々と情報ありがとうございます。
その後、nkfというコマンドがソース公開されてたので、これで出来ないかと
思っています。
サブジェクトのiso-2022-jpが変換できるか微妙ですが試してます。
ありがとうございました。


77:デフォルトの名無しさん
06/06/16 13:42:43
ちゃんとMIMEの仕様も読んだ方がいいよ。

メールをメールフォルダに取り込むのと、
メッセージを解析するのは全然別の仕事なんだけど、
その辺ちゃんと整理して理解出来ているのかね?


78:50
06/06/16 14:32:55
>77
thx
今回は、一般的なメールクライアントではなく、特定業務のクライアントで、
送られてくる文字コードとかも決まっているし、メールをユーザに見せるわけ
でもないから、違うエンコードでメール本文解析できなかったらエラーにする
だけっす。

nkfでサブジェクトも本文も文字コード変換できますた。
あとは、こいつをファイルからではなく文字列を渡して変換かましてくれる
ようにするだけだだだ。


79:デフォルトの名無しさん
06/06/16 14:36:18
>>78
何故libiconvなりiconvプロセスなりを使わない?
OSによっては標準で入っているのだけれど。

80:デフォルトの名無しさん
06/06/16 15:07:16
>>79
一般論で横レススレ浮けど、iconv は不正な文字があると変換に失敗
してしまうから、いろんなクライアントから送られてくる怪しげなものを
処理するには向いていないと思う。

ある程度適当にやってくれる nkf の方がより向いているというか。

81:デフォルトの名無しさん
06/06/16 15:39:10
Structured fieldはQ encodingだからiconv()だけで解決するのは無理ざんしょ。

82:71
06/06/16 16:31:09
>>72,>>74-75
レス有難うゴザイマシタ。

諦めて、UDPデータ内にMAC入れる事で合意を取る方向にします。

83:デフォルトの名無しさん
06/06/16 16:50:33
>>82
いや、だから MAC アドレスで認証したら駄目だって。


84:デフォルトの名無しさん
06/06/16 19:17:01
>>83
暗号化したデータ部に入れる方向(に変換)なので、大丈夫かなぁと。
心配オカケシマシタ。

85:デフォルトの名無しさん
06/06/16 19:55:33
認証*みたいな*ことならOKでしょ
疑いだしたらきりがない

86:デフォルトの名無しさん
06/06/16 19:59:35
>>55
ありがとうございます
ソースで10分の1、実行速度で6000分の1に短縮することが出来ました

87:デフォルトの名無しさん
06/06/16 22:28:59
というか、MACアドレスは常に外に晒されているわけで。
*みたいな*ことにも不適格。

88:デフォルトの名無しさん
06/06/16 22:40:18
いいじゃん。君が仕様決めるんじゃないんだし。

89:デフォルトの名無しさん
06/06/16 23:04:58
不適切なことをする自由は誰にもあるわな。

90:デフォルトの名無しさん
06/06/16 23:06:55
MACアドレス査証によるリスクと、MACアドレスを使わない場合の開発コストを天秤にかけて
妥当なほうを取ればええ。

91:デフォルトの名無しさん
06/06/16 23:15:26
どんな天秤だよ!
まずパスワード認証その他の認証方法と天秤だろw

92:デフォルトの名無しさん
06/06/16 23:26:51
MACアドレスを使いたいってことは、使用できる機器を制限したいってことじゃないか?
ID形式だとそれこそ詐称しまくられるリスクがある。
まぁ質問者じゃないから、なんともいえんが

93:デフォルトの名無しさん
06/06/16 23:40:06
>>92
君のレベルは問題外

94:デフォルトの名無しさん
06/06/17 00:07:08
>>93
批判するなら具体的にやりましょう。

95:デフォルトの名無しさん
06/06/17 00:29:17
> MACアドレスを使いたいってことは、使用できる機器を制限したいってことじゃないか?
「認証したい」って言ってるんだから明らかに自明なことを、
なんでそんなにしたり顔で言えるのか理解に苦しむ。

96:デフォルトの名無しさん
06/06/17 00:59:56
>>95
質問者は認証したいとはひとことも言ってないが。

97:デフォルトの名無しさん
06/06/17 01:05:01
それに質問者がどのようなものにMACアドレスを使いたいのかわからないが、例えばWebアプリケーションや、
クライアントサーバ型アプリケーションなら当然パスワード認証等も考慮するだろうし、それをしないとも
書いていない。

98:デフォルトの名無しさん
06/06/17 01:12:04
DRM関連じゃないの?<MACアドレス
コンテンツのmove不可とか。

99:デフォルトの名無しさん
06/06/17 02:05:56
なんか必死な奴は、どこかから仕入れた知識で、MACアドレスの偽装方法を知っていることを
自慢したいのでしょう。

100:デフォルトの名無しさん
06/06/17 02:59:26
まぁ認証といっても、使用者の認証、ライセンスの認証、使用機器の認証といろいろとあるからな。

101:デフォルトの名無しさん
06/06/17 03:03:37
>>96
>>73

102:デフォルトの名無しさん
06/06/17 03:07:06
認証みたいなことをしたいんだろ。
つか、お前何が言いたいの?

103:デフォルトの名無しさん
06/06/17 03:09:56
>>101
つか、この程度のニュアンスも汲み取れないんじゃ、プログラマやめたほうがいいよ。

104:デフォルトの名無しさん
06/06/17 03:16:06
変なことで盛り上がるなよw

105:デフォルトの名無しさん
06/06/17 03:20:20
からまれたもんで。

106:デフォルトの名無しさん
06/06/17 03:26:07
まぁ>>91を見る限り、相手がNIU固定のファームかもしれないなんて想像もできないんだろうけど。

107:デフォルトの名無しさん
06/06/17 03:26:55
お前しつこいよw

108:デフォルトの名無しさん
06/06/17 03:27:56
うるさい。俺は徹底的にやるよ。
ガキは叩きのめす主義なんで。

109:デフォルトの名無しさん
06/06/17 03:29:38
頓珍漢なこと言って諌められたからって切れなくてもいいのに

110:デフォルトの名無しさん
06/06/17 03:30:42
具体的に指摘しなされ

111:デフォルトの名無しさん
06/06/17 03:31:42
ひょっとして>>90のことか?
これが頓珍漢なことに見えるんなら、マジ相手にならんわ。

112:デフォルトの名無しさん
06/06/17 03:32:58
必死だな

113:デフォルトの名無しさん
06/06/17 03:33:56
まぁお前が.>>91なんだろうけど、逃げたいなら何も書かずにほっとけよ。追いかけないから。

114:デフォルトの名無しさん
06/06/17 03:38:20
>>112
お前が>>91なら>>106に対するコメント書いとけ。俺もう寝るから。書かなくてほっといてもいいぞ。

115:デフォルトの名無しさん
06/06/17 03:40:01
起きて監視しているんだろw

116:デフォルトの名無しさん
06/06/17 11:53:51
教えて下さい!

finde ./ の結果が

AAA
AAA/BBB
AAA/BBB/hoge1.txt
AAA/BBB/hoge2.txt
AAA/BBB/hoge3.txt
AAA/BBB/CCC/hoge4.txt
AAA/BBB/CCC/DDD
AAA/BBB/CCC/DDD/EEE
AAA/BBB/FFF/GGG/hoge5.txt
AAA/BBB/FFF/GGG/hoge6.txt
AAA/BBB/FFF/GGG/HHH
AAA/BBB/FFF/III/hoge7.txt
AAA/BBB/FFF/III/JJJ
AAA/BBB/FFF/III/JJJ/KKK
AAA/BBB/FFF/III/JJJ/KKK/LLL
AAA/BBB/FFF/III/JJJ/KKK/LLL/MMM

となっていて、ツリーにファイルを持たないフォルダのみを
抜き出したいです。



117:デフォルトの名無しさん
06/06/17 11:55:38
↓こんな感じです。

AAA/BBB/CCC/DDD
AAA/BBB/CCC/DDD/EEE
AAA/BBB/FFF/GGG/HHH
AAA/BBB/FFF/III/JJJ
AAA/BBB/FFF/III/JJJ/KKK
AAA/BBB/FFF/III/JJJ/KKK/LLL
AAA/BBB/FFF/III/JJJ/KKK/LLL/MMM

先輩は、find . -type d -emptyと言い残して旅に出ましたが
動きませんでした…

OSはこれです。シェルがどうこうはよくわかりません。。。
SunOS devcvs01 5.9 Generic_118558-05 sun4u sparc SUNW,UltraAX-i2


118:デフォルトの名無しさん
06/06/17 12:38:14
動くよ。

それに、それプログラミングじゃないだろ。
それから、その結果欲しければ、find AAA (ryだろ。

119:デフォルトの名無しさん
06/06/17 12:50:31
シェルプログラミングスレどっかにあったな。UNIX板か?
実はSolarisのfindには-emptyオプションがないとか?
GNUとMac(BSD)にはあった。

120:デフォルトの名無しさん
06/06/17 13:25:45
そのとーりSolarisには-emptyないよ

>>118
ぷw

121:デフォルトの名無しさん
06/06/17 13:41:01
いかなる環境でも安定して動作し、
複数の計算機、複数の別プロセスから同時にアクセスされても安全が保障され、
複数プロセス間で、ロックを試みた順番で確実にロック権が回ってくる

そんな「完璧な」ファイルロックというのは可能でしょうか?
それとも、日本語の文字コードを完全には自動識別できないのと同じように、
ファイルのロックにも「完全」というのは存在しないのでしょうか?

ヒントやキーワードだけでいいから教えて下さい

122:デフォルトの名無しさん
06/06/17 14:05:27
>>121
ヒント: スレ違い

123:デフォルトの名無しさん
06/06/17 16:49:41
>>116
空のディレクトリを抜き出したい理由は?
カレント配下の空のディレクトリを消したいだけなら
find . -depth -type d -exec rmdir {} \;
でできるけど。
#-depthを指定しないと、例えばDDDを消そうとして失敗してからEEEを消すことになる。

124:デフォルトの名無しさん
06/06/17 17:02:27
AAA/BBB/CCC/DDD/EEE
がファイルなのかディレクトリなのか区別出来ないけど

125:デフォルトの名無しさん
06/06/22 05:41:18
pthread使用していてgdbでデバッグしてるとepoll_waitが割り込みで何度も止まってるのよ
何のシグナル受け取ってるのか判別する方法ないかな

126:ゆーき
06/06/26 00:07:54
ハイパー初心者ですが、octaveでsubplotをファイルに保存したいのですが、print -depsや
gset term postscript enhancedではできません。。。
だれかやりかたを教えて下さい。お願いします。

127:デフォルトの名無しさん
06/06/26 00:18:58
>>125
OSを書け

128:デフォルトの名無しさん
06/06/26 03:54:31
epoll_waitと書いている以上、Linuxだろ?
straceで追っかけてみるのはどーだろ?

129:デフォルトの名無しさん
06/06/26 12:59:50
LinuxならSIGALRMじゃないの?

$(GLIBC)/nptl/*eintr*辺り読んでみて。

130:デフォルトの名無しさん
06/06/30 03:23:01
>>121
ありとあらゆる環境上でなんて事実上不可能

> 複数プロセス間で、ロックを試みた順番で確実にロック権が回ってくる

「ロックを試みた順番」という単語一つとっても

- ロックマネージャーに届いた順番?
- ロックにあたるFunctionを呼び出したとき?

など曖昧かと..
PostgreSQLなどのDBMSのソースとかがヒントになるかもしれない。

131:デフォルトの名無しさん
06/06/30 14:01:44
Linuxの一般のユーザーwatashiとtaninがいて、
watashiがtaninさんの/home/tanin/workのオーナーになりたいので、
こんなプログラムを作って、
int main()
{
int uid = 509;// watashiのuid
int gid = 100;// watashiのgid
chown("/home/tanin/work", uid, gid);
}
gccでコンパイルしたあと、ルートになって
chmod ug+s a.out
して、watashiユーザーで実行してみたのですが、失敗しました。
この方法では、watashiはtaninさんのディレクトリのオーナーになることはできませんか?


132:デフォルトの名無しさん
06/06/30 14:25:35
chown root a.out
したか?
setuidされたプログラムは、そのプログラムファイルの所有者
の権限で動くのであって、自動的にroot権限で動く訳ではない。

133:デフォルトの名無しさん
06/06/30 14:28:01
>chown root a.out
>したか?
ああ、その通りでした。忘れてました。
rootにchownしらた無事動きました。お騒がせしました。

134:デフォルトの名無しさん
06/06/30 15:09:49
>>131
chown()の返り値を調べてエラー処理をするように。

int result = chown(〜);
if (result != 0) {
perror("/home/tanin/work");
exit(1);
}

135:デフォルトの名無しさん
06/07/01 23:34:34
fork() で子プロセスを立ち上げるプログラムを書いてるのですが
(親プロセスは走り続けてイベントを待ち、時々 fork() して子プロセスに仕事をさせる)
子がシグナルを受けたときの親の wait() (wait4()) を呼ぶタイミングがわかりません。

親プロセスに SIGCHLD のハンドラをインストールしてその中で wait4() してみたの
ですが、 それだと子プロセスがゾンビになる場合があるようです。(うまくいく場合もある)
なお wait4() には WNOHANG をセットしてそこで親がハングしないようにしています。

シグナルハンドラ内の wait4() で駄目なときは、どうやらもっと後で wait4() を呼ぶと
うまく子プロセスが刈られるようです。
ただ、それは実験的に親のプログラムのいろんなところに wait4() を埋め込んだ
らゾンビが出ないのがわかっただけなんで、それでいいとは思えません。

こういうプログラムの場合 wait() ってどういうタイミングで呼べばいいんでしょうか。
あるいはタイミング以外に問題があるでしょうか。(ソースコードがないと厳しいかな?)
ちなみに OS は Mac OS X 10.4.6 です。

136:135
06/07/01 23:43:08
あ、ちなみに wait4() を呼ぶときは WNOHANG かつ pid に -1 をセットして
ループで全てのプロセスを処理するようにしています。

137:デフォルトの名無しさん
06/07/01 23:51:23
ハンドラ内で、signalがブロックされているうちに、
たくさん子プロセスが終了するけど、
ハンドラ終了のタイミングなどでループで全部処理しきれてない、
くらいしか想像付かない。

138:デフォルトの名無しさん
06/07/02 00:05:12
>>135
waitは基本的にSIGCHLDのシグナルハンドラで呼ぶ。
同タイミングで大量の子プロセスが死ぬ場合は問題になるのかも
しれないけど、俺はそんな経験nothing。

親プロセスが、子プロセスの死亡時に、プロセスを成就させる以外の
仕事をしないなら、forkを二回行って子プロセスを親プロセスのグループから
切り離すという手もある。
詳しくはUNIX Programming FAQ参照。

139:135
06/07/02 02:38:11
どうも、早速のフォローありがとうございます。
>>137 >>138
そうですよね、基本はSIGCHLDのハンドラ内で wait() すればいいんですよね。

すいません、書き込みしたあともう少し調べてみたら、どうも状況によってシグナル
ハンドラが呼ばれない場合があるようです。なんとなく、子プロセスが大量にメモリを
使う処理をした後はハンドラが呼ばれていないような...
子プロセスは、同時に起動するのは1つだけです。
ps で見ると子プロセスのステータスは Z になっているんですが。

ちなみに sigaction() を使っているんですが、これって、一回ハンドラが呼ばれたら
また再インストールする、なんて必要はないですよね?
フラグは SA_RESTART だけを設定しています。

もしかして OS のバグ?
とりあえず動くものを作らないといけないので、さしあたり新たに fork() する前に
wait4() するようにしてゾンビの増殖は防げるようになりましたが... 気持ち悪い。

140:デフォルトの名無しさん
06/07/02 03:21:20
wait4が-1を返した時のerrnoもちゃんとチェックしてる?
死んだ子がいないと判断できるのはerrno==ECHILDの時だけだよ。
wait4が-1返しても、errnoがEINTRの時なんかは、まだ子が取り残されてる場合がある。

141:デフォルトの名無しさん
06/07/02 09:07:35
> もしかして OS のバグ?

こう思うときの99%は自分の理解不足が本当の原因。


142:プログラミング
06/07/03 15:16:08
誰かほんとにすいませんっ↓この問題分かる人教えてください!!
お願いします!(>△<)
言語はdelphiです。

?モンテカルロ法を使って1/3を求めるプログラムを作くれ。
 モンテカルロ法を試行する回数をプログラム実行時に選べるようにせよ。

?2分法を使って188の5乗根を求めよ。途中経過を分かりやすく画面に表せ。

143:デフォルトの名無しさん
06/07/03 15:22:12
問題がunix固有ではまるでない感じなので、Delphiのスレに行ったほうが
回答が得られやすいと思われるが、宿題は自分でやろうな。


144:デフォルトの名無しさん
06/07/03 15:26:16
>>143
作くれなんて問題の宿題があるか?

と思ったがあるみたいだ。

145:プログラミング
06/07/03 15:30:08
はいっありがとうございます!
delphiの掲示板いってみます(>▽<)☆

146:デフォルトの名無しさん
06/07/05 15:47:29
この質問はここでいいのかな?
pathName = "/home/guest/"
fileName = "*.txt"

として、文字列

"/home/guest/*.txt"

にマッチしたファイルのみ削除する関数を作りたいのですが、opendir()関数だと、
指定したパス内の全ファイル名を取得することはできたのですが、
特定のパターンにマッチしたファイルのみ取り出すにはどうしたらよいでしょうか?

remove_files(char *pathName, char *fileName)
{
...
...

}
こんな関数を作りたいのです。
良い方法はありますか??

147:デフォルトの名無しさん
06/07/05 15:53:55
つ fnmatch(3)
つ glob(3)

148:デフォルトの名無しさん
06/07/05 15:55:44
Cでやりたいの?
bashのsourceにlibglobってのがあるからそれ使って。

shell scriptでやるのが簡単だとおもうけれど。
"/bin/ls home/guest/*.txt"をpopen(2)するとか。

149:デフォルトの名無しさん
06/07/05 16:06:29
みなさんありがとうございます。
そうですCでやりたいです。
普段windowsのVCで書いているのですが、10年ぶりくらいに
Linuxのgccで少し作業することになりまして、難儀してます。

150:デフォルトの名無しさん
06/07/05 16:23:04
>>149
system("/bin/rm /home/guest/*.txt");
Unix系だからこそ、適材適所で書くべきだと思う。

151:デフォルトの名無しさん
06/07/06 03:56:05
>>150

>>148 の言ってる popen の方が良いと思う


152:デフォルトの名無しさん
06/07/06 07:33:33
削除するのにls?

153:デフォルトの名無しさん
06/07/06 18:03:37
そのツッコミは想定内です

154:デフォルトの名無しさん
06/07/06 19:27:54
>>147を無かったことにしたい流れに萎え

155:デフォルトの名無しさん
06/07/06 22:42:47
>147か>150の二択でいいんでね?

156:デフォルトの名無しさん
06/07/06 23:53:55
シェルを通すやり方の場合、もしユーザーの任意のパターンを受け付けるのであれば、
"; /bin/rm -rf /"
なんていうパターンが与えられても大丈夫でないといけない。

157:デフォルトの名無しさん
06/07/07 01:12:25
頭のおかしい人登場

158:デフォルトの名無しさん
06/07/07 02:41:02

漏れなら

" & /bin/rm -rf / "

にする


159:デフォルトの名無しさん
06/07/07 03:13:57
俺のお気に入りの削除方法おしえちゃう

zip -rm /tmp/.zip *


160:デフォルトの名無しさん
06/07/07 03:23:46
俺は

chmod -R a-x * .*

161:デフォルトの名無しさん
06/07/07 13:39:05
すんません、シェルスクリプトをCに置き換えたいのですが
システムコマンドって使えるですか?

たとえば

/usr/bin/aumix -v $VOL

この$VOLを可変したいのですが
Cってのがこのaumixコマンドを扱えるのかな?と・・・・・・・・・・・・・ヒントキボン

162:デフォルトの名無しさん
06/07/07 14:47:48

int callsumix(char *vol)
{
  char *buf = (char *)malloc(適当);
  sprintf(buf, "/usr/bin/aumix -v %s", vol);
  system(buf);
  free(buf);
  return 適当;
}

163:デフォルトの名無しさん
06/07/07 14:49:20
>>162 おお!(゚∀゚)神のヨカーン 

なるほどね、printfで!
echo "aumix -....

ありがd!!

164:デフォルトの名無しさん
06/07/07 14:55:44
int callsumix(char *vol)
{
return execl("/usr/bin/aumix", "/usr/bin/aumix", "-v", vol);
}

165:デフォルトの名無しさん
06/07/07 14:58:22
null terminate するの忘れた。

return execl("/usr/bin/aumix", "/usr/bin/aumix", "-v", vol, NULL);

166:デフォルトの名無しさん
06/07/07 15:03:48

int callsumix(char *vol)

次の人 ↑ ここ直してね

167:デフォルトの名無しさん
06/07/07 15:11:01
>>165-166 ちょwww! なんかいろいろと方法があるんすね?!
execl ですかそうですか

ちょっとGoogleも見てきます

つーか、Bashで書いたものをコンパイルできればいいっすねw

168:デフォルトの名無しさん
06/07/07 15:21:08
baka

169:デフォルトの名無しさん
06/07/07 15:24:02
その昔、商用でシェルスクリプトのコンパイラってあったよね?

170:デフォルトの名無しさん
06/07/07 15:44:03
>>168  つД`)・゚・。・゚゚・*:.。..。.:*・゚
>>169  ヽ(`Д´)/それだ!( ゚д゚)ホスィ…でもCshだけだったり

main関数ってなんだよぉ〜
Cなんてわかんねぇよぉ〜
逝ってきますorz
でも、CでUNIXコマンドがいじれることがわかったのはテラウレシス!

171:デフォルトの名無しさん
06/07/07 20:29:39
>>167

exec*系は成功したら帰ってこないからな。
ついでにforkもペアで調べるんだ。

172:デフォルトの名無しさん
06/07/07 21:53:35
nix はその最初の敷居が高すぎる

#define exec fork() ? wait() : execl

exec("sh", "-c", "/usr/bin/aumix -v $VOL")

もうfork はこれでよくね?うごかねえかな?

173:デフォルトの名無しさん
06/07/07 22:44:15
お前それ以前にCわかってないやん

174:デフォルトの名無しさん
06/07/08 19:12:31

 ; を忘れてるのは見逃すとして、

とりあえず

fork() ? wait() : execl("sh", "-c", "/usr/bin/aumix -v $VOL");

になるのか。
pid == 0 の方が実行される方か。



175:デフォルトの名無しさん
06/07/08 19:17:04
(;´Д`)

176:デフォルトの名無しさん
06/07/08 22:48:40
fork()が-1返した時は?

177:デフォルトの名無しさん
06/07/08 22:51:50
wait() へ行くから大丈夫なん?

178:デフォルトの名無しさん
06/07/08 23:37:01
execlが返ってきたら危険だね


179:デフォルトの名無しさん
06/07/09 00:41:54
orz わかんねぇよ フォークだかボークだかエクセルだかワードだか・・・・

180:デフォルトの名無しさん
06/07/09 00:46:28
素直にif - else ifで書くがよろし。

181:デフォルトの名無しさん
06/07/09 01:14:59
>>179
ああぁぁぁぁ!!!! 先を越されたorz それは俺が言おうと(ry

182:デフォルトの名無しさん
06/07/09 02:03:38
マニュアル嫁よ

183:デフォルトの名無しさん
06/07/09 13:07:51
すんません、「おはよう世界」から出直します

184:デフォルトの名無しさん
06/07/09 16:37:56
printf("Good morning world.\n");

185:デフォルトの名無しさん
06/07/09 17:39:22
こんにちわ世界でしたね ̄|_|・・・..●ゲヴォルガァ

186:デフォルトの名無しさん
06/07/09 19:34:36
printf("Welcome to HELL WORLD.\n");

187:デフォルトの名無しさん
06/07/09 20:04:09
char *p = NULL;

while(1){
 printf("%02x\n", *p++);
}

188:デフォルトの名無しさん
06/07/10 20:14:34
>>169
漏れシェルのコンパイラって使ったことあるよ。
「これでシェルスクリプトが100倍速く走るぜ!」
と思って感動にうち震えながら試したが、軽くも速くもならなかった。
漏れがボンクラプログラマ−たから? ええ。それも、そうなんですけどね

189:デフォルトの名無しさん
06/07/11 00:42:55
システムコールってわかんねぇよww
もういいや、Shellscriptで書きつづけるよ
どうせ100行以上のプログラムなんて書けないしヲ
チマチマプログラマーでいいっすヲ

190:デフォルトの名無しさん
06/07/11 00:48:35
man 2に入ってるのがシステムコール
man 3に入ってるのがライブラリ

191:デフォルトの名無しさん
06/07/11 19:35:29
man coに入ってるのがチソポ


192:デフォルトの名無しさん
06/07/11 19:49:08
ハァッ、ハァッ、ハァッ、ハァッ!

193:デフォルトの名無しさん
06/07/11 20:52:46
>>189
ヒント:URLリンク(www.linux.or.jp)

194:デフォルトの名無しさん
06/07/12 11:03:43
そもそも、ぽまえらの使用言語は何でつか?

195:デフォルトの名無しさん
06/07/12 11:10:34
C, C++, perl, sh, Java, BeanShellといったところ。

196:デフォルトの名無しさん
06/07/12 11:26:38
C, C++, java, python, Haskell, scheme, bash, zsh, emacs lisp

197:デフォルトの名無しさん
06/07/12 11:32:08
Brankfuck, INTERCAL, HQ9+

198:デフォルトの名無しさん
06/07/12 11:46:12
C

199:デフォルトの名無しさん
06/07/12 14:27:58
書く頻度でRuby, Java, sh, Cってとこか。

200:デフォルトの名無しさん
06/07/12 20:52:42
C++, Perl, C, sh, Ruby, Fortran

201:デフォルトの名無しさん
06/07/12 20:54:59
C, Java, C#, Common Lisp

202:デフォルトの名無しさん
06/07/12 21:09:10
C# って、もしかして MONO 使ってるの?

203:デフォルトの名無しさん
06/07/12 21:23:33
日常的なスクリプティングは Scheme or CL でこなしたいんだけど、
いかんせん力量不足だなぁ...

204:デフォルトの名無しさん
06/07/12 21:43:13
なんでそんなにつかえるんだよー
英語すら使えない漏れはモウダメポ..._〆(゚▽゚*)ですね

205:デフォルトの名無しさん
06/07/12 22:35:30
>>202


206:デフォルトの名無しさん
06/07/13 01:09:43
>>204
yacc/lex。最狂のスクリプト言語「日本語」を開発すべく技術者募集(嘘)

207:デフォルトの名無しさん
06/07/13 11:07:35
2ch語でプログラムできればどんなにいいかw

米 プログラムテスト
米 コメント
表示 "こんちわ世界"
ゴルァ 米 割り込み
糸冬 了

208:デフォルトの名無しさん
06/07/13 11:36:27
>>207
kwsk

209:デフォルトの名無しさん
06/07/13 15:25:31
OpenMotifとMotifのちがいってなんですか?
MotifのコードはOpenMotifでもコンパイルできますか?

210:デフォルトの名無しさん
06/07/13 21:41:06
ライセンス

211:デフォルトの名無しさん
06/07/19 00:43:18
質問なのですが、pipeを使って実際のパイプラインのような処理をする場合
どのように繋いでいけばいいのでしょうか?
例えば標準入力から ls | grep a | cat という入力が入ってきた場合はスペース毎に
区切り argmv[0]=ls、argmv[1]=|、argmv[2]=grep...と格納し、
最初の処理でargmv[0]の標準出力をパイプに置き換え、次の処理でargmv[2]と
argmv[3]の標準入力、標準出力をパイプに置き換え、最後の処理でargmv[5]の
標準入力をパイプに置き換えるという感じです。


212:デフォルトの名無しさん
06/07/19 00:45:43
オナニーはひとに頼らずに自分一人でやれよ

213:デフォルトの名無しさん
06/07/19 00:53:57
再帰的に処理すればいいじゃん。

214:デフォルトの名無しさん
06/07/19 01:12:11
>>211
Q&Aかよ!

215:デフォルトの名無しさん
06/07/19 02:00:42
>>211
「俺コード」で説明するのはやめてくれ。

まずパイプを二個作り、
・lsの標準出力をpipe1のfd[1]
・grepの標準入力をpipe1のfd[0]
・grepの標準出力をpipe2のfd[1]
・catの標準出力をpipe2のfd[0]
に繋ぎ変えればOK。

216:215
06/07/19 02:03:19
あっと、それからその手のコードを書くときは
・何かを標準出力に出力するだけのプログラム
・標準入力をそのまま標準出力にするプログラム
を作って、それを使ったほうがいろいろ便利。デバッグプリントとか入れやすいし。

217:デフォルトの名無しさん
06/07/19 03:20:38
shellでも作ろうとしてるんだろうか?

218:デフォルトの名無しさん
06/07/19 03:33:44
宿題らしい。

219:デフォルトの名無しさん
06/07/19 04:02:29
最近の大学生は「特殊化-一般化」の概念も知らないんだろうか。

220:デフォルトの名無しさん
06/07/19 04:29:47
一人の特殊なサンプルで最近の大学生は〜と一般化してしまうのもどうかと思う


221:デフォルトの名無しさん
06/07/19 07:34:40
一人のサンプルが、特殊なのか一般なのかを問うている疑問なのでは?


222:デフォルトの名無しさん
06/07/19 10:06:18
揚げ足とりしてる暇あったら回答してあげようよ

223:デフォルトの名無しさん
06/07/19 12:10:24
やだ。なんかこいつむかつくもん。

224:デフォルトの名無しさん
06/07/19 13:03:19
実際 csh とか tcsh とかは

hoge | fuga | hage

みたいなコマンドライン受け取ったら
>>211 の処理をするんでしょうか?
(違う方法で実現してる気がするけど)


あと

hoge -o hage | ukiki -e `echo *` | fuga -p 'kuso' | puka

みたいになってるとややこしいね

225:デフォルトの名無しさん
06/07/19 13:10:01
>>224
ソース見れば?

226:デフォルトの名無しさん
06/07/19 13:35:36
本物がどうやってるかはおいといて・・・

1.まず区切り( ; とか | とか & とか・・・)で分ける
・hoge -o hage
・ukiki -e `echo *`
・fuga -p 'kuso'
・puka

2.空白で区切ったそれぞれを評価
・hoge    ←そのままでおけ
・-o     ←そのままでおけ
・`echo *` ←バッククォート内を評価した結果に置き換える

3.それぞれパイプで繋げて実行

みたいな感じやろ。

227:デフォルトの名無しさん
06/07/19 14:05:54
今、『OS自作入門』を読んでる途中で、ちょっと興味があるので実験してみました。
書いたコードは、URLリンク(kansai2channeler.hp.infoseek.co.jp) です。
このコードは次のことを行います。
・親プロセスがpipeを二つ作る
・lsの結果をmycat(自作)を二回通す
・起動するアプリは、パイプでつなげながらfork-exec

ここで質問なんですが、
・一番最後のclose(fd[0][1])を実行しないと、子プロセスが終了しないのですが、
 それはなぜでしょうか?
・なんか、もっと簡単にできないでしょうか。
 今の方針だと、n個のプロセスを起動する場合は、n-1個のpipeが必要で、
 それぞれfork後、関係ないpipeを全部closeしなければなりません。

なお、maycat.cは以下です。
#include <unistd.h>
int main()
{
char buf[1];
while (read(0, buf, 1) > 0) {
write(1, buf, 1);
}
return 0;
}


次ページ
最新レス表示
スレッドの検索
類似スレ一覧
話題のニュース
おまかせリスト
▼オプションを表示
暇つぶし2ch

5369日前に更新/142 KB
担当:undef