死锁产生的四个条件:1、互斥使用(资源独占)一个资源每次只能给一个进程使用.2、不可强占(不可剥夺)资源申请者不能强行的从资源占有者手中夺取资源,资源只能由占有者自愿释放.3、请求和保持(部分分配,占有申请)一个进程在申请新的资源的同时保持对原有资源的占有(只有..
分类:
编程语言 时间:
2016-04-24 18:57:59
阅读次数:
232
生产者与消费者模型生产者与消费者模型是一种描述进程间同步与互斥的一个方式,在这个模式下有两类人,一个是不停产生数据的生产者,一个是不停获取数据的消费者,为了效率最高,就必须保持两者之间的同步与互斥。为了在生产者与消费者使用mutex保持互斥的前提下,posix版本下..
分类:
编程语言 时间:
2016-04-23 01:51:11
阅读次数:
240
基础知识多个线程同时访问共享数据时可能会冲突,比如两个线程都要把某个全局变量增加1,这个操作在某平台需要三条指令完成:1.从内存读变量值到寄存器2.寄存器的值加13.将寄存器的值写回内存可能你执行到这三条指令中的某一条时,时间片到,另一个线程也执行这三条指令,就会发..
分类:
编程语言 时间:
2016-04-22 16:44:51
阅读次数:
272
一个进程中可以有多个线程,这些线程共享进程的资源,但当多个线程访问同一个资源时,在并不能保证操作是原子的情况下,就会产生冲突而使数据最终的结果不准确,像上次我们提到的将一个数进行加1操作需要三步:将数据从内存中取出;将数据加1;再将数据放回内存中,当多个线程..
分类:
编程语言 时间:
2016-04-22 16:41:18
阅读次数:
251
可以知道,一条语句对一个变量进行+1操作,转成汇编指令共有三条:将这个变量从内存中取出;将其值加1;再将加后的结果放回内存;当一个进程中的两个线程同时进行这个操作时,本来期望的是将变量进行两次加1,但中途有可能当一个线程刚从内存中将变量取出就被切换暂停了,此时..
分类:
编程语言 时间:
2016-04-19 20:12:10
阅读次数:
257
线程的同步与互斥A.mutex(互斥量)+1操作:从内存读变量到寄存器->寄存器的值加1->将寄存器的值写回内存举一个例子:1#include<stdio.h>
2#include<pthread.h>
3staticintg_count=0;
4void*print_bug(void*arg)
5{
6//intindex=0;
7inttmp=0;
8while(tmp++<..
分类:
编程语言 时间:
2016-04-19 00:44:50
阅读次数:
188
线程概念:它是运行在进程内部的的一个基本执行流,多线程的控制流程可以长期并存,一个进程中的数据段和代码段都是被该进程中的多个线程共享的,若定义一个函数,每个线程都可以调用,若定义一个全局变量,每个线程都可以访问。线程还共享进程的以下内容:1.文件描述符表2.当..
分类:
编程语言 时间:
2016-04-19 00:44:36
阅读次数:
241
一、mutex互斥量同步:就是对资源的访问有序。互斥:就是任一时刻来说只有一个在执行;但是对于多线程的程序来说,访问冲突的问题是很普遍的,解决的办法是引入互斥锁(Mutex,MutualExclusiveLock),获得锁的线程可以完成“读-修改-写”的操作,然后释放锁给其它线程,没有获得锁的线..
分类:
编程语言 时间:
2016-04-17 23:27:37
阅读次数:
299
线程的同步与互斥多个线程同时访问共享数据时可能会发生冲突,比如两个线程同时把一个全局变量加1,结果可能不是我们所期待的:我们看这段代码的执行结果:#include<stdio.h>#include<stdlib.h>#include<pthread.h>staticintg_count=0;void*thread(void*arg)..
分类:
编程语言 时间:
2016-04-17 23:27:20
阅读次数:
288
线程的同步与互斥多线程往往会引起很多问题,比如下面所示代码:1#include<stdio.h>
2#include<pthread.h>
3intg_val=0;
4void*test(void*arg)
5{
6intcount=5000;
7inttmp=0;
8while(count-->0)
9{
10tmp=g_val;
11printf("%sg_val=%d\n",arg,g_val);
12g_val=..
分类:
编程语言 时间:
2016-04-17 17:59:16
阅读次数:
248