test_press_write2.c 1.53 KB
Newer Older
1 2 3
/*
 * This file is part of the zlog Library.
 *
4
 * Copyright (C) 2011 by Hardy Simpson <HardySimpson1984@gmail.com>
5
 *
6
 * Licensed under the LGPL v2.1, see the file COPYING in base directory.
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
 */

#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <pthread.h>
#include <sys/stat.h>
#include <fcntl.h>

#include "zlog.h"

static long loop_count;


void * work(void *ptr)
{
	long j = loop_count;
26
	int rc;
27
static char log[] = "2012-06-14 20:30:38.481187 INFO   24536:140716226213632:test_press_zlog.c:36 loglog\n";
28 29 30
	char file[20];
	sprintf(file, "press.%ld.log", (long)ptr);

31 32
	int fd;
	fd = open(file, O_CREAT | O_WRONLY | O_APPEND , 0644);
33
	//FILE *fp;
34

35
	while(j-- > 0) {
36 37
		rc = write(fd, log, sizeof(log)-1);
		//fwrite(log, sizeof(log)-1, 1, fp);
38
	}
39 40
	//fclose(fp);
	close(fd);
41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
	return 0;
}


int test(long process_count, long thread_count)
{
	long i;
	pid_t pid;
	long j;

	for (i = 0; i < process_count; i++) {
		pid = fork();
		if (pid < 0) {
			printf("fork fail\n");
		} else if(pid == 0) {
			pthread_t  tid[thread_count];

			for (j = 0; j < thread_count; j++) { 
				pthread_create(&(tid[j]), NULL, work, (void*)j);
			}
			for (j = 0; j < thread_count; j++) { 
				pthread_join(tid[j], NULL);
			}
			return 0;
		}
	}

	for (i = 0; i < process_count; i++) {
		pid = wait(NULL);
	}

	return 0;
}


int main(int argc, char** argv)
{
	if (argc != 4) {
		fprintf(stderr, "test nprocess nthreads nloop\n");
		exit(1);
	}


	loop_count = atol(argv[3]);
	test(atol(argv[1]), atol(argv[2]));
	
	return 0;
}