-1

次のコードスニペットに出くわしました

    int seg1 = shmget( number, 1, 0660 );
    if( -1 != seg1 )
    {
        struct shmid_ds buf;
        shmctl( seg1, IPC_RMID, &buf );
        fprintf( stderr, "Removed existing shared memory segment" );
    }
    int seg = shmget( number, 2 * size, IPC_CREAT | 0660 );
    Buffer =  (char*) shmat( seg, NULL, 0 );

質問:

1) shmget( number, 1, 0660 ) f IPC_CREAT または IPC_EXCL が指定されておらず、0660 のみが指定されている場合、デフォルトの IPC_ は何ですか? はこれを説明しません/

2) サイズが 1 バイトのキー番号に対して shmget を実行し、次に IPC_RMID を実行してから、より大きなスペースで同じキーの shmget を再度実行する必要があるのはなぜですか?

4

1 に答える 1

1

1) shmget( number, 1, 0660 ) f IPC_CREAT または IPC_EXCL が指定されておらず、0660 のみが指定されている場合、デフォルトの IPC_ は何ですか? はこれを説明しません/

デフォルトでは、どちらのオプションも適用されません。セグメントは、すでに存在する場合にのみ開かれます。

2) サイズが 1 バイトのキー番号に対して shmget を実行し、次に IPC_RMID を実行してから、より大きなスペースで同じキーの shmget を再度実行する必要があるのはなぜですか?

目的は、サイズに関係なく、既存の共有メモリ セグメントを削除することだけです。が既存のセグメントのサイズよりも大きい場合、shmget関数は失敗するsizeため、1 つを使用すると失敗しないことが保証されます。

于 2013-10-27T15:35:31.860 に答える