Cのスレッドを使用して123を無限に印刷します
ここでは、cプログラミング言語のスレッドを使用して123シーケンスを無限に繰り返し印刷する必要があります。
コードから必要なサンプル出力を見てみましょう。
1 2 3 1 2 3 1 2 3 1 2 3
このためには、Cプログラミング言語で並行して実行されている3つのスレッドを使用する必要があります。そして、最初のスレッドで1に初期化される変数で、その値は最後の値に基づいて更新されます。そして、関数で無限ループを実行します。
例
ソリューションを実装するためのプログラムを見てみましょう。
#include <stdio.h> #include <pthread.h> pthread_cond_t cond1 = PTHREAD_COND_INITIALIZER; pthread_cond_t cond2 = PTHREAD_COND_INITIALIZER; pthread_cond_t cond3 = PTHREAD_COND_INITIALIZER; pthread_mutex_t lock = PTHREAD_MUTEX_INITIALIZER; int value = 1; void *foo(void *n){ while(1) { pthread_mutex_lock(&lock); if (value != (int)*(int*)n) { if ((int)*(int*)n == 1) { pthread_cond_wait(&cond1, &lock); } else if ((int)*(int*)n == 2) { pthread_cond_wait(&cond2, &lock); } else { pthread_cond_wait(&cond3, &lock); } } printf("%d ", *(int*)n); if (value == 3) { value = 1; pthread_cond_signal(&cond1); } else if(value == 1) { value = 2; pthread_cond_signal(&cond2); } else if (value == 2) { value = 3; pthread_cond_signal(&cond3); } pthread_mutex_unlock(&lock); } return NULL; } int main(){ pthread_t tid1, tid2, tid3; int n1 = 1, n2 = 2, n3 = 3; pthread_create(&tid1, NULL, foo, (void *)&n1); pthread_create(&tid2, NULL, foo, (void *)&n2); pthread_create(&tid3, NULL, foo, (void *)&n3); while(1); return 0; }
出力
1 2 3 1 2 3 1 2 3 1 2 3 1 2 3….
-
CプログラムでO(1)の余分なスペースを使用して、nxnスパイラル行列を出力します。
正の整数nが与えられ、時計回りにO(1)の余分なスペースのみを使用して、nxnのスパイラル行列を作成します スパイラル行列は、円の原点から始まり時計回りに回転するスパイラルのように機能する行列です。したがって、タスクは、2→4→6→8→10→12→14→16→18から始まるO(1)スペースを使用して、行列をスパイラル形式で印刷することです。 以下にスパイラル行列の例を示します- 例 Input: 3 Output: 9 8 7 2 1 6 3 4 1 無制限のスペースでコードを解くのは簡単になりますが、最
-
awkの使用を開始する方法
awk、sed、およびgrepは、LinuxまたはUNIXコマンドラインで私のお気に入りのツールの3つです。それらはすべてかなり強力です。今日は、awkを使いやすくするためにawkでクラッキングを行う方法を見ていきます。次に、物事をもう少し楽しくするための便利なawkワンライナーをいくつか見ていきます。 AWKは、ファイルまたはデータストリームのいずれかでテキストベースのデータを処理するために設計されたプログラミング言語です。 1970年代にベル研究所で作成されました。かなり古いですが、その年齢に騙されないでください。それはそれが何をするかで非常に強力で効率的です。さあ、手を汚しましょう。