【线程】多线程创建,传参,共享数据,终止,等待,清除
2013-08-04 15:47
295 查看
多线程优点
使用线程的理由之一:和进程相比,它是一种“节俭”的多任务操作方式。在linux系统下,启动一个新的进程必须分配给他独立的地址空间,建立众多的数据表来维护它的代码段、堆栈段和数据段,这是一种“昂贵的”多任务工作方式。
运行于一个进程中的多个线程,他们之间使用相同的地址空间,而且线程间彼此切换所用的时间也远远小于进程间切换所用的时间。据统计,一个进程的开销大约是一个线程开销的30倍左右。
使用多线程理由之二:
线程间方便的通信机制。对不同进程来说,他们具有独立的数据空间,要进行数据传递只能通过进程间通信的方式进行,这种方式不仅耗时而且很不方便。线程则不然,由于同一进程下的线程之间共享数据空间,所以一个线程的数据可以直接为其它线程所用,这不仅快捷,而且方便。
除了以上优点之外,多线程作为一种多任务、并发的工作方式,有如下优点:
使多CPU系统更加有效,操作系统会保证当线程数不大于CPU数目时,不同的线程运行在不同的CPU上。
改善程序结构。一个既长又复杂的进程可以考虑分为多个线程,成为几个独立或者半独立的部分,这样的程序会有利于理解和修改。
创建线程
#include<pthread.h> int pthread_create(pthread_t *tidp,const pthread_attr_t *attr,void *(*start_rtn)(void),void arg)
tidp:线程ID
attr:线程属性(通常为空)
start_rtn:线程要执行的函数
arg:start_rtn的参数
编译
因为pthread的库不是LINUX系统库,所以在编译的时候要加上 -lphread#gcc filename -lphread -o 。。。
线程实例之pthread_join()
thread 1 start thread 1 push complete thread 1 exit code 1 thread 2 start thread 2 push complete cleanup :thread 2 second handler cleanup :thread 2 first handler thread 2 exit code 2
View Code
相关文章推荐
- 多线程创建、传参、共享数据、终止、等待、清除【转】
- 黑马程序员--读写字节数组,随机读写流,集合IO的思维导图,多线程部分,单例设计模式,线程和进程的概念,Java中的线程的创建方式,线程的随机性,线程的状态图,多线程操作共享数据的安全性,死锁
- Linux 线程(创建/等待/终止)
- 多线程的原子操作和线程数据共享
- .Net最简单的创建多线程主线程等待所有线程执行完成的例子
- 线程的创建、等待、终止、分离
- 多线程操作共享资源时 设置线程等待
- 线程创建、等待、终止
- 多线程编程1 --线程创建,退出,等待,分离
- java多线程与线程并发五:多个线程访问共享对象和数据的方式
- linux基础编程:多线程基础总结:线程创建 终止 线程同步/互斥量/条件变量/信号灯
- 【多线程】-线程范围内共享数据的两种方式
- java多线程之多个线程访问共享对象和数据的方式
- JAVA笔记13__创建线程/线程休眠/等待线程终止/线程中断/守护线程
- 多线程和并发库应用五-线程间数据共享
- Android多线程研究(5)——线程之间共享数据
- 多线程编程-线程的创建和终止
- 多线程编程-线程的创建和终止
- Linux多线程编程-线程的创建和终止
- Android多线程研究(5)——线程之间共享数据