7-41 pthread mutexをプロセス間で利用する


#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/shm.h>
#include <pthread.h>
#include <sys/wait.h>

int
main()
{
  pthread_mutex_t *m;
  pthread_mutexattr_t mat;
  int shmid;
  pid_t pid;

  /* mutex用に共有メモリを利用 */
  shmid = shmget(IPC_PRIVATE, sizeof(pthread_mutex_t), 0600);
  if (shmid < 0) {
    perror("shmget");
    return 1;
  }

  m = shmat(shmid, NULL, 0);
  if ((int)m == -1) {
    perror("shmat");
    return 1;
  }

  /* mutexのattributeを設定する準備 */
  pthread_mutexattr_init(&mat);

  /* mutexをプロセス間で利用する設定を行う */
  /* これを行わないとプロセス内でのみ有効のmutexになります */
  if (pthread_mutexattr_setpshared(&mat, PTHREAD_PROCESS_SHARED) != 0) {
    perror("pthread_mutexattr_setpshared");
    return 1;
  }

  pthread_mutex_init(m, &mat);

  /* fork()でプロセスを生成 */
  pid = fork();

  printf("[%s] before pthread_mutex_lock()\n",
      pid == 0 ? "child" : "parent");

  if (pthread_mutex_lock(m) != 0) {
    perror("pthread_mutex_lock");
    return 1;
  }

  printf("[%s] press enter\n", pid == 0 ? "child" : "parent");

  getchar();

  if (pthread_mutex_unlock(m) != 0) {
    perror("pthread_mutex_unlock");
    return 1;
  }

  printf("[%s] after pthread_mutex_unlock()\n",
      pid == 0 ? "child" : "parent");

  shmdt(m);

  if (pid != 0) {
    /* 子プロセスの終了を待つ */
    wait(NULL);

    printf("[%s] after wait()\n", pid == 0 ? "child" : "parent");
    /* 作成した共有メモリを削除 */

    if (shmctl(shmid, IPC_RMID, NULL) != 0) {
      perror("shmctl");
      return 1;
    }
  }

  return 0;
}

拙著「Linuxネットワークプログラミング」の紹介

IPv6基礎検定

YouTubeチャンネルやってます!