目录
一、线程和进程的区别
- 进程是资源分配得最小单位,线程是CPU调度得最小单位。
- 线程在进程下行进。
- 一个进程可以包含多个线程。
- 进程间不会相互影响,线程之间会相互影响,一个线程挂掉将导致整个进程挂掉。
- 进程使用的内存地址可以上锁,即一个线程使用某些共享内存时,其他线程必须等它结束,才能使用这一块内存。-"互斥锁"
- 进程使用的内存地址可以限定使用量。-“信号量”
二、相关函数
安装man手册pthread相关
sudo apt-get install manpages-posix-dev
void *func(void *arg)//函数返回值和形参void *
{
return NULL;
}
/*创建一条线程*/
int pthread_create(pthread_t *thread,
const pthread_attr_t *attr,void *(*start_routine) (void *), void *arg);
/*信号量*/
int sem_init(sem_t *sem, int pshared, unsigned int value);//初始化信号量
int sem_wait(sem_t *sem);//等待信号量,初始值为0进入休眠
int sem_post(sem_t *sem);//唤醒通知接收线程
/*互斥量*/
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER
pthread_cond_t convar = PTHREAD_COND_INITIALIZER
int pthread_mutex_lock(pthread_mutex_t *mutex);//锁
int pthread_cond_wait(pthread_cond_t *cond,pthread_mutex_t *mutex);//等待被唤醒
int pthread_mutex_unlock(pthread_mutex_t *mutex);//解锁
int pthread_cond_signal(pthread_cond_t *cond);//唤醒等待cond的线程(通知接收线程条件成立)
三、源代码(包含注释)
如果没有进入休眠等待唤醒会导致while占用大量CPU,可以使用top命令查看
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <unistd.h>
#include <string.h>
//#include <semaphore.h>
char arr[512];
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
//sem_t sem;
void *myfunc(void *arg)
{
while(1)
{
//sem_wait(&sem );
pthread_mutex_lock(&mutex);
pthread_cond_wait(&cond,&mutex);//等待被唤醒,进入休眠,不然会占用大量CPU
printf("%s\r\n",arr);
pthread_mutex_unlock(&mutex);
}
return NULL;
}
int main()
{
char arr_buf[512];
pthread_t pid;//创建一个线程指向的标识
pthread_create(&pid, NULL,myfunc, NULL);//创建一条线程
//sem_init(&sem, 0, 0);//初始化信号量
while(1)
{
/*没输入时程序在这里等待,主线程对互斥量的占用很少
不然可能导致主线程一直占用互斥量但是其他线程无法使用*/
fgets(arr_buf,512,stdin);//从键盘获取输入
pthread_mutex_lock(&mutex);//打开互斥锁
memcpy(arr,arr_buf,512);//将arr_buff中的数据复制到arr中
pthread_mutex_unlock(&mutex);//关闭互斥锁
pthread_cond_signal(&cond);//唤醒等待cond的线程
//sem_post(&sem);//唤醒接收线程
}
return 0;
}