⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 stat_sigwait.c

📁 linux下多线程程序设计,包括signals,mutex,simple_once
💻 C
字号:
/********************************************************
 * An example source module to accompany...
 *
 * "Using POSIX Threads: Programming with Pthreads"
 *     by Brad nichols, Dick Buttlar, Jackie Farrell
 *     O'Reilly & Associates, Inc.
 *
 ********************************************************
 * stat_sigwait.c
 *
 * Simple example of pthreads and signals.
 */

#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <signal.h>
#include <time.h>
#include <sys/types.h>

#include <pthread.h>

#define MAX_NUM_THREADS  10

pthread_mutex_t stats_lock = PTHREAD_MUTEX_INITIALIZER;
int mean, samples, total;

void *report_stats(void *p)
{
	int caught;
	sigset_t  sigs_to_catch;
	
	/* Identify our thread */
	printf("\nreport_stats() started.\n"); 
	
	/*
	* We inherited a thread sigmask with all the signals 
	* blocked.  So, we can wait on whatever signals we're
	* interested in and (as long as no other thread waits
	* for them) we'll be sure return from sigwait() to
	* handle it.
	*/ 
	
	/* set this thread's signal mask to block out SIGUSR1 */
	sigemptyset(&sigs_to_catch);
	sigaddset(&sigs_to_catch, SIGUSR1);
	
	for (;;) 
	{
		sigwait(&sigs_to_catch, &caught);
		
		pthread_mutex_lock(&stats_lock);
		mean = total/samples;
		printf("\nreport_stats(): mean = %d, samples = %d\n", mean, samples);
		pthread_mutex_unlock(&stats_lock);
	}
	return NULL;
}
/*
 * worker_thread --
 * 
 * Don't read too much into what this thread does.  It's
 * a very simpleminded example.  The only interesting thing
 * it does is write to the global statistics data-- which
 * means the thread processing the signal has to protect 
 * against simultaneous access.
 */
void *worker_thread(void *p) 
{
	int item;
	time_t now;
	int *amtp=(int *)p;
	
	for (;;) 
	{
		sleep((*amtp)*9);
		now = time(NULL);
		
		pthread_mutex_lock(&stats_lock);
		total+=((int)now)%60; /* probably not the safest thing to do but it's just an example */
		samples++;
		pthread_mutex_unlock(&stats_lock);
	}
	/* Won't get here.  */
	return NULL;
}

extern int	main(void)
{
	int       i;
	pthread_t threads[MAX_NUM_THREADS];
	int       num_threads = 0;
	sigset_t  sigs_to_block;
	struct    sigaction action;
	
	
	/* Identify our thread */
	printf("main() running in thread 0x%x\n", pthread_self()); 
	
	/* 
	* Set this thread's signal mask to block SIGUSR1
	* Other thread's will inherit the mask
	*/
	sigemptyset(&sigs_to_block);
	sigaddset(&sigs_to_block, SIGUSR1);
	pthread_sigmask(SIG_BLOCK, &sigs_to_block, NULL);
	
	/* spawn statistics reporting thread */
	pthread_create(&threads[num_threads++], NULL, report_stats, NULL);
	
	/* spawn the threads */
	for (i=num_threads; i<MAX_NUM_THREADS; i++) 
	{
		pthread_create(&threads[num_threads++], NULL, worker_thread, &i);
	}
	
	printf("main()\t\t\t\t%d threads created\n",num_threads);
	
	/* wait until all threads have finished */
	for (i = 0; i < num_threads; i++) 
	{
		pthread_join(threads[i], NULL);
		printf("main()\t\tjoined to thread %d \n", i);
	}
	
	printf("main()\t\tall %d threads have finished. \n", num_threads);
	
	return 0;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -