Linux下C编程:线程操作

7 篇文章 0 订阅

Linux下多线程开发一般是采用pthread库,因此编译项目的时候需要链接pthread库才可以。

创建线程很简单,int pthread_create(pthread_t*thread, pthread_attr_t *attr, ... );//

void pthread_exit(); //结束线程

int pthread_join(pthread th, void **thread_return); //挂起当前进程直至指定线程终止,这个可以用以进行一些简单的线程同步。

多线程开发中最重要的问题就是线程同步了,Linux按照POSIX标准提供了两种同步机制,互斥锁(mutex)和条件变量(condition variable),实际上这两中机制可以配合使用。

下面这个是书上给的一个利用互斥锁和同步变量实现的生产者/消费者例子:

/*
 ============================================================================
 Name        : threadmemo.c
 Author      : 
 Version     :
 Copyright   : Your copyright notice
 Description : Hello World in C, Ansi-style
 ============================================================================
 */

#include <stdio.h>
#include <pthread.h>
#define BUFFER_SIZE 4
#define OVER (-1)
struct producers
{
	int buffer[BUFFER_SIZE];
	pthread_mutex_t	lock;
	int		readpos, writepos;
	pthread_cond_t	notempty;
	pthread_cond_t	notfull;
};

void init(struct producers *b)
{
	pthread_mutex_init(&b->lock,NULL);
	pthread_cond_init(&b->notempty,NULL);
	pthread_cond_init(&b->notfull,NULL);
	b->readpos=0;
	b->writepos=0;
}

void put(struct producers *b, int data)
{
	pthread_mutex_lock(&b->lock);
	while((b->writepos+1)%BUFFER_SIZE==b->readpos)
	{
		pthread_cond_wait(&b->notfull,&b->lock);
	}

	b->buffer[b->writepos]=data;
	b->writepos++;
	if(b->writepos>=BUFFER_SIZE) b->writepos=0;
	pthread_cond_signal(&b->notempty);
	pthread_mutex_unlock(&b->lock);
}

int get(struct producers *b)
{
	int data;
	pthread_mutex_lock(&b->lock);
	while(b->writepos==b->readpos)
	{
		pthread_cond_wait(&b->notempty,&b->lock);
	}
	data=b->buffer[b->readpos];
	b->readpos++;
	if(b->readpos>=BUFFER_SIZE) b->readpos=0;
	pthread_cond_signal(&b->notfull);
	pthread_mutex_unlock(&b->lock);
	return data;
}

struct producers  buffer;
void *producer(void *data)
{
	int n;
	for(n=0;n<10;n++)
	{
		printf("Producer : %d-->\n",n);
		put(&buffer,n);
	}
	put(&buffer,OVER);
	return NULL;
}

void *consumer(void *data)
{
	int d;
	while(1)
	{
		d=get(&buffer);
		if(d==OVER) break;
		printf("Consumer: --> %d\n",d);
	}
	return NULL;
}

int main()
{
	pthread_t tha,thb;
	void *retval;
	init(&buffer);
	pthread_create(&tha,NULL,producer,0);
	pthread_create(&thb,NULL,consumer,0);
	pthread_join(tha,&retval);
	pthread_join(thb,&retval);
	return 0;

}
  现在就是有点疑惑,查阅了一些资料,有人说pthread是用户态线程库,但是又有人说不是,说和内核线程是一一对应的,不知道哪种说法准确。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值