开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第37天,点击查看活动详情
1、通信技术IPC(InterProcess Communication)
1、进程线程区别
1.进程占内存,比如父子进程copy内存空间 线程共享内存空间
2.线程切换和创建速度比进程快 进程开销大约是线程的30倍
3.线程因为共享内存,所以通信快
2、线程(创建退出等待)
1.API
int pthread_create(pthread_t *thread, const pthread_attr_t *attr,void *(*start_routine) (void *), void *arg);
创建
返回值:成功0失败-1
参数1:pthread_t型指针t1
参数2:线程属性,NULL
参数3:函数指针
参数4:无类型数据
例: 函数void* func1(void*arg) 输出主函数传过来的值,*((int*)arg) set=pthread_create(&t1,NULL,func1,(void*)¶m);
void pthread_exit(void *retval);
退出
参数:无类型指针,int char都可以,但线程函数里定义要static,保证内存不释放,主函数才能打印。 例: static int set=10 pthread_exit((void*)&set)
int pthread_join(pthread_t thread, void **retval);
等待,主函数阻塞一直等待线程退出 参数1:线程t1,创建线程的参数1 参数2:线程退出返回的值,二级指针 例: int *pret=NULL pthread_join(t1,(void**)&pret) 输出直接输出pret地址内容
pthread_t pthread_self(void);
返回线程id 返回值:长整型 例: 主线程和新线程都有id %ld输出 (unsigned long)pthread_self()
int pthread_equal(pthread_t t1, pthread_t t2);
id比较,相等返回非0,否则0
3、互斥量,锁
1.互斥量本质上是锁 加锁,解锁在线程开头结尾,可以保证线程在执行完之前不被打断。(主函数可以打断)
2.API
int pthread_mutex_init(pthread_mutex_t *restrict mutex,const pthread_mutexattr_t *restrict attr)
互斥量创建(锁) 参数1:全局变量,指针 参数2:默认属性互斥量,NULL
int pthread_mutex_destroy(pthread_mutex_t *mutex)
销毁锁 参数:创建锁时的全局变量
int pthread_mutex_lock(pthread_mutex_t *mutex)
加锁 参数:全局变量指针
int pthread_mutex_unlock(pthread_mutex_t *mutex)
解锁 参数:全局变量指针
3.线程的共享内存 线程改变全局变量
3、什么是死锁
2个线程有时会造成死锁,2个锁
一个线程拿到锁1,要拿锁2
另一个拿到锁2,要拿锁1
造成2个线程都不能继续运行下去
4、条件
1.一个线程等待触发条件。 2.API
int pthread_cond_init
创建
pthread_cond_destroy
销毁
int pthread_cond_wait(pthread_cond_t *cond,pthread_mutex_t *mutex)
等待 参数1:条件 参数2:锁
pthread_cond_signal
触发 参数:条件&cond
pthread_cond_broadcast
广播
5、线程初始化宏
动态初始化
pthread_cond_init(&cond, NULL);
静态初始化
pthread_cond_t cond=PTHREAD_COND_INITIALIZER
6、生产者消费者
数据缓冲期访问