Linux でのマルチスレッドおよびマルチプロセス クラッシュのシミュレーションに関する簡単な説明

Linux でのマルチスレッドおよびマルチプロセス クラッシュのシミュレーションに関する簡単な説明

結論:
マルチスレッド環境では、スレッドの 1 つがクラッシュすると、他のスレッド (プロセス全体) もクラッシュします。
マルチプロセス環境でプロセスの 1 つがクラッシュしても、残りのプロセスには影響はありません。

マルチスレッド

#include <stdio.h>
#include <文字列.h>
#include <stdlib.h>
#include <pthread.h>
#include <assert.h>

void *fun1(void *arg)
{
 printf("fun1 enter\n");
 ながら(1)
 {
  printf("%s\n", __FUNCTION__);
  スリープ(1000 * 1000);
 }
 printf("fun1 exit\n");
 戻り値 ((void *)1);
}

void *fun2(void *arg)
{
 printf("fun1 enter\n");
 スリープ(1000 * 3000);
 char * ptr = (char *)malloc(sizeof(char));
 printf("ptr1: 0x%x\n", ptr);
 ptr = NULL;
 printf("ptr2: 0x%x\n", ptr);
 解放(ptr);
 memcpy(ptr, "123", 3);
 printf("ptr3: 0x%x\n", ptr);
 printf("fun2 exit\n");
 戻り値 ((void *)2);
}

int メイン(void)
{
 pthread_t tid1、tid2;
 整数エラー;
 
 エラー = pthread_create(&tid1, NULL, fun1, NULL);
 アサート(0 == エラー);
 エラー = pthread_create(&tid2, NULL, fun2, NULL);
 アサート(0 == エラー);
 
 printf("メイン結合...\n");
// getchar();
 pthread_join(tid1, NULL);
 pthread_join(tid2, NULL);
 
 0を返します。
}

マルチプロセス

#include <stdio.h>
#include <文字列.h>
#include <stdlib.h>
#include <pthread.h>
#include <assert.h>

void fun(void *arg)
{
 printf("fun1 enter\n");
 スリープ(1000 * 3000);
 char * ptr = (char *)malloc(sizeof(char));
 printf("ptr1: 0x%x\n", ptr);
 ptr = NULL;
 printf("ptr2: 0x%x\n", ptr);
 解放(ptr);
 memcpy(ptr, "123", 3);
 printf("ptr3: 0x%x\n", ptr);
 printf("fun2 exit\n");
 戻る ;
}

int main(int argc, char *argv[])
{
 アサート(2 == argc);
 pid_t pid;
 整数 i;
 i=0; i<atoi(argv[1]); i++)の場合
 {
  pid = fork();
  0 より大きい場合
  {
   printf("フォークエラー");
   終了(1);
  }
  そうでない場合(0 == pid)
  {
   printf("子のPIDは%luです\n", (unsigned long)getpid());
   楽しい(NULL);
   終了(0);
  }
 }
 
 printf("親PIDは%lu\n", (unsigned long)getpid());
 while(-1 != wait(NULL)); //すべてのサブプロセスが終了するまで待機します printf("main return\n");
 getchar();
 
 0を返します。
}

マルチスレッド クラッシュとマルチプロセス クラッシュの Linux シミュレーションに関するこの記事はこれで終わりです。マルチスレッド クラッシュとマルチプロセス クラッシュの Linux シミュレーションに関するより関連性の高い記事については、123WORDPRESS.COM で以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Linux での C\C++ マルチプロセスおよびマルチスレッド プログラミング例の詳細な説明
  • Linux BASHマルチプロセス並列処理方式の実装
  • Linux で PHP マルチプロセスを実装する方法の共有
  • Linux でのシンプルなマルチスレッド ミューテックス ロックの例の簡単な分析
  • Linux での C 言語によるマルチスレッド プログラミング
  • Linux C マルチスレッドプログラミングのサンプルコード
  • Linux のマルチスレッドの詳細な説明と簡単な例
  • Linux でのマルチスレッド プログラミング (パート 3)
  • Linuxのマルチスレッドはミューテックスを使用してスレッドを同期します
  • Linux マルチスレッド ロック属性設定方法

<<:  MySQL における distinct と group by の違い

>>:  JavaScript es6 における var、let、const の違いの詳細な説明

推薦する

MySQL 5.7.16 無料インストール版のインストールと設定方法のグラフィックチュートリアル

この記事ではMySQL 5.7.16のインストールと設定方法を記録します。具体的な内容は以下のとおり...

nginx がアップストリーム アドレスにジャンプしない問題の解決方法

序文今日、nginx で非常に奇妙な問題に遭遇しました。フロントエンドの tomcat がページにジ...

vuexの強制リフレッシュによるデータ損失問題の分析

vuex 永続状態基本原則: すべての vuex データをローカルストレージに保存し、ページが更新さ...

Linux で fdisk を使用してディスクをパーティション分割する方法

Linux パーティションでよく使用されるコマンド: fdisk、MBR パーティション テーブルの...

Linux CentOS6.5 yum インストール mysql5.6

この記事では、Linux yumを使用してmysql5.6をインストールする簡単な手順を参考までに紹...

CSS フォント、テキスト、リストのプロパティの詳細な紹介

1. フォントのプロパティcolorは、div{color:red;}のようにテキストの色を指定しま...

Docker+jenkins+python3環境を使用して非常に詳細なチュートリアルを構築する

序文:自動化を記述した後、毎日サーバー上で実行する必要があります。このような問題に遭遇しました。Je...

MacでDockerがホストマシンにpingできない問題を解決する

解決Docker for Macに付属するLinux仮想マシン(軽量ですが、ソケットファイルを使用し...

MySQLクエリ最適化分析チュートリアルをステップバイステップで教えます

序文MySQL は、強力なクエリ機能、高いデータ一貫性、高いデータ セキュリティ、およびセカンダリ ...

MySQL 8.0.23 のレプリケーション アーキテクチャにおけるスレーブ ノードの自動フェイルオーバー

私はしばらく MGR と連絡を取り合ってきました。MySQL 8.0.23 の登場により、MySQL...

HTML で複数のフォームのテキスト ボックスを揃える方法

フォームのコードは図の通りです。スタイルシートがまだ追加されていないため、フォームが整列されておらず...

Linux ipcsコマンドの使用

1. コマンドの紹介ipcs コマンドは、Linux のプロセス間通信機能の状態を報告するために使用...

Navicat 8でMySQL用のデータベースを作成する方法

ウェブサイトを開発する場合、データを保存するためにデータベースを使用する必要があることがよくあります...

プログレッシブ ウェブ アプリ (PWA) の開発方法

目次概要必要とするアプリURL PWA にはどのような技術コンポーネントが必要ですか?マニフェストフ...