linux线程
线程:轻量级进程,在资源、数据方面不需要进行复制
不间断地跟踪指令执行的路径被称为执行路线
进程的结构:task_struck;地址空间
线程:轻量级的进程
在同一个进程中创建的线程,在共享进程的地址空间
在linux里用task_struct来描述一个线程,进程和线程都参与统一的调度
线程是共享相同地址空间的多个任务
------------------------------------------------------------------------------------
一个进程中的多个线程共享以下资源:
1.代码段/指令
** 2.静态数据(全局变量、静态变量)
3.进程中打开的文件描述符
4.信号处理函数
5.当前工作目录
6.用户id:uid
7.组id:gid
每个线程私有的资源如下:
1.线程id:tid
2.程序计数器(PC)和寄存器
** 3.栈/堆栈(stack):局部变量
4.错误码(errno)
5.信号掩码
6.执行状态和属性
-----------------------------------------------------------------------------------------------
创建线程:
int pthread_create(pthread_t *thread, const pthread_attr_t *attr,void *(*start_routine) (void *), void *arg);
thread:创建的线程的id号
attr:指定线程的属性,NULL-----表示使用缺省属性,默认
start_routine:线程执行的函数
void *(*start_routine) (void *)--------------参数和返回值都被定义为类型是void*的指针,以允许他们指向任何类型的值
arg:传递给线程执行的函数的参数
删除线程/线程退出:
void pthread_exit(void *retval);
retval:线程退出时,返回值的地址
控制线程:等待一个线程结束/以阻塞的方式等待线程的结束
int pthread_join(pthread_t thread, void **retval);
thread:要等待的进程
retval:指向线程返回值的地址,不需要的话---NULL
======================================================================================================
| 在进行多线程编程时,一般主线程初始化/创建其他线程后,不做任何操作,调用pthread_join等待线程结束 |
| 因为若主线程有操作的话,可能因为操作失误而关闭进程,这样就会影响其他的线程操作 |
======================================================================================================
线程间互斥和同步:
----------------------------------------------------------------------------------------------------------------------------------------------------
线程间同步(条件变量):
条件变量是线程的一种同步机制。
条件变量给多个线程提供一个汇合的场所
条件变量是公共资源,条件变量与互斥锁一起使用,允许线程以没有竞争的方式等待特定的条件发生。
条件变量是由互斥锁进行保护的。线程在改变条件变量的状态之前,必须先锁住互斥锁。
初始化条件变量:
int pthread_cond_init(pthread_cond_t *restrict cond,const pthread_condattr_t *restrict attr);
attr---->条件变量的属性
NULL---->默认属性
或者
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
等待条件变量:
int pthread_cond_wait(pthread_cond_t *restrict cond,pthread_mutex_t *restrict mutex);
功能:1.先解锁
2.暂停该线程
唤醒条件变量:
int pthread_cond_signal(pthread_cond_t *cond);
功能:使一个由cond阻塞的线程运行
-----------------------------------------------------------------------------------------------------------------------------------------------------------
线程间互斥:引入互斥锁(mutual exclusion)目的是用来保证共享数据操作的完整性和正确性
互斥锁:主要用来保护临界资源。每个临界资源都由一个互斥锁来保护,任何时候最多只有一个线程能访问临界资源。进程必须要先获得互斥锁才能访问临界资源,访问完临界资源后释放互斥锁。如果无法获得互斥锁,线程就会阻塞/等待,直到获得锁为止。
初始化互斥锁:int pthread_mutex_init(pthread_mutex_t *restrict mutex, const pthread_mutexattr_t *restrict attr);
mutex----------互斥锁
attr----------互斥锁的属性,NULL---表示缺省/默认属性
或者
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
加锁:等待互斥锁解开然后再锁住互斥锁
int pthread_mutex_lock(pthread_mutex_t *mutex);
解锁:int pthread_mutex_unlock(pthread_mutex_t *mutex);
-----------------------------------------------------------------------------------------------------------------------------------------------------------------
信号量:bijkstra算法
信号量也是一种同步的机制
由信号量来决定线程是继续运行还是阻塞等待
信号量代表一类资源,他的值表示系统中该资源的数量
信号量是受保护的变量,只能通过函数来访问
初始化信号量:
int sem_init(sem_t *sem, int pshared, unsigned int value);
sem:初始化的信号量
pshared:信号量的共享范围,0-----线程之间 !0------进程之间
value:信号量的初始值
申请资源( P 操作):
if(信号量 > 0)
{
信号量-1;
申请资源的任务继续运行;
}else
{
申请资源的任务阻塞等待;
}
int sem_wait(sem_t *sem);
int sem_trywait(sem_t *sem);
int sem_timedwait(sem_t *sem, const struct timespec *abs_timeout);
释放资源( V 操作):
if(没有任务等待资源)
{
信号量+1;
}else
{
唤醒第一个等待的任务,让这个任务继续运行;
}
int sem_post(sem_t *sem); //唤醒信号量
---------------------------------------------------------------------------------------------------------------------------------------------
Posix 定义的信号量:
** 无名信号量
有名信号量
linux线程的更多相关文章
- [转载]Linux 线程实现机制分析
本文转自http://www.ibm.com/developerworks/cn/linux/kernel/l-thread/ 支持原创.尊重原创,分享知识! 自从多线程编程的概念出现在 Linux ...
- linux线程的实现
首先从OS设计原理上阐明三种线程:内核线程.轻量级进程.用户线程 内核线程 内核线程就是内核的分身,一个分身可以处理一件特定事情.这在处理异步事件如异步IO时特别有用.内核线程的使用是廉价的,唯一使用 ...
- linux线程的实现【转】
转自:http://www.cnblogs.com/zhaoyl/p/3620204.html 首先从OS设计原理上阐明三种线程:内核线程.轻量级进程.用户线程 内核线程 内核线程就是内核的分身,一个 ...
- Linux线程-创建
Linux的线程实现是在内核以外来实现的,内核本身并不提供线程创建.但是内核为提供线程[也就是轻量级进程]提供了两个系统调用__clone()和fork (),这两个系统调用都为准备一些参数,最终都用 ...
- Linux线程学习(一)
一.Linux进程与线程概述 进程与线程 为什么对于大多数合作性任务,多线程比多个独立的进程更优越呢?这是因为,线程共享相同的内存空间.不同的线程可以存取内存中的同一个变量.所以,程序中的所有线程都可 ...
- Linux线程学习(二)
线程基础 进程 系统中程序执行和资源分配的基本单位 每个进程有自己的数据段.代码段和堆栈段 在进行切换时需要有比较复杂的上下文切换 线程 减少处理机的空转时间,支持多处理器以及减少上下文切换开销, ...
- Linux 线程(进程)数限制分析
1.问题来源公司线上环境出现MQ不能接受消息的异常,运维和开发人员临时切换另一台服务器的MQ后恢复.同时运维人员反馈在出现问题的服务器上很多基本的命令都不能运行,出现如下错误:2. 初步原因分析和 ...
- Linux 线程与进程,以及通信
http://blog.chinaunix.net/uid-25324849-id-3110075.html 部分转自:http://blog.chinaunix.net/uid-20620288-i ...
- linux 线程的内核栈是独立的还是共享父进程的?
需要考证 考证结果: 其内核栈是独立的 206 static struct task_struct *dup_task_struct(struct task_struct *orig) 207 { 2 ...
- Linux 线程模型的比较:LinuxThreads 和 NPTL
Linux 线程模型的比较:LinuxThreads 和 NPTL GNU_LIBPTHREAD_VERSION 宏 大部分现代 Linux 发行版都预装了 LinuxThreads 和 NPTL,因 ...
随机推荐
- Oracle 中 decode 函数用法
Oracle 中 decode 函数用法 含义解释:decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该函数的含义如下:IF 条件=值1 THEN RETURN(翻译 ...
- CSS解决未知高度垂直居中
尽管有CSS的vertical-align特性,但是并不能有效解决未知高度的垂直居中问题(在一个DIV标签里有未知高度的文本或图片的情况下). 标准浏览器如Mozilla, Opera, Safari ...
- Redis 3.0 与 3.2 配置文件变化
一.Redis3.0 与 3.2 配置文件对比 1. clone redis git clone https://github.com/antirez/redis.git 2. checkout分支 ...
- java基础知识(十一)java反射机制(下)
1.什么是反射机制? java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法,对于任意一个对象都能够调用他的属性和方法,这种动态获取属性和方法的功能称为java的反射机制. ...
- Dom4j解析xml文件
dom4j是一个Java的XML API,类似于jdom,用来读取的XML文件,由于它是将文件解析完存放在内存当中的,所以不适合解析大的XML文件,但就方便性和性能方面,一定程度要优于JDK中Domc ...
- Interleaving String
https://leetcode.com/problems/interleaving-string/ Given s1, s2, s3, find whether s3 is formed by th ...
- (转载)html中table的使用方法
colspan表示该一储存格向右打通的栏数. rowspan表示该一储存格向下打通的栏数. colspan是表示横向合并单元格,colspan=“3”表示水平合并三个td rowspan是表示竖直 ...
- SQL Server子查询实例
例子一 SELECT COUNT(*) FROM ( SELECT [PersonID] FROM [tbiz_AssScore] GROUP BY PersonID ) M 语法说明: 1).FRO ...
- mysql基础类型知识总结
Mysql知识回顾 http://www.educity.cn/wenda/596225.html http://blog.csdn.net/dyllove98/article/details/928 ...
- 2015 史考特(Scottrade)开户指南 + 招商银行香港一卡通汇款【图文教程】
最近刚开始炒美股.总的来说分为两步:一是开户,即选一个美股券商开设股票交易账户:二是汇款注资,把人民币换成美元转账到股票交易账户上.上述第一点其实相对简单,美股券商大多都对美国以外的外国人开放申请,且 ...