博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
线程概念及死锁的理解
阅读量:2379 次
发布时间:2019-05-10

本文共 1035 字,大约阅读时间需要 3 分钟。

1.什么是进程(Process)和线程(Thread)?有何区别?

进程是一个程序运行占用内存空间。线程是程序的一代码段。一个或多个线程组成一个进程。进程可以执行多个任务,每个任务都是线程。
2.分段和分页
  页是信息的物理单位,分页是为实现离散分配方式,以消减内存的外零头,提高内存的利用率;或者说,分页仅仅是由于系统管理的需要,而不是用户的需要。
  段是信息的逻辑单位,它含有一组其意义相对完整的信息。分段的目的是为了能更好的满足用户的需要。
  页的大小固定且由系统确定,把逻辑地址划分为页号和页内地址两部分,是由机器硬件实现的,因而一个系统只能有一种大小的页面。段的长度却不固定,决定于用户所编写的程序,通常由编辑程序在对源程序进行编辑时,根据信息的性质来划分。
  分页的作业地址空间是一维的,即单一的线性空间,程序员只须利用一个记忆符,即可表示一地址。分段的作业地址空间是二维的,程序员在标识一个地址时,既需给出段名,又需给出段内地址。

3. **死锁**:

产生死锁的原因:一是系统提供的资源数量有限,不能满足每个进程的使用;二是多道程序运行时,进程推进顺序不合理。

产生死锁的必要条件是:1、互斥条件;2、不可剥夺条件(不可抢占);3、部分分配;4、循环等待。

根据产生死锁的四个必要条件,只要使其中之一不能成立,死锁就不会出现。为此,可以采取下列三种预防措施:

1、采用资源静态分配策略,破坏”部分分配”条件;
2、允许进程剥夺使用其他进程占有的资源,从而破坏”不可剥夺”条件;
3、采用资源有序分配法,破坏”环路”条件。

死锁的避免不严格地限制死锁的必要条件的存在,而是系统在系统运行过程中小心地避免死锁的最终发生。最著名的死锁避免算法是银行家算法。死锁避免算法需要很大的系统开销。

解决死锁的另一条途径是死锁检测方法,这种方法对资源的分配不加限制,即允许死锁的发生。但系统定时地运行一个”死锁检测”程序,判断系统是否已发生死锁,若检测到死锁发生则设法加以解除。

解除死锁常常采用下面两种方法:1、资源剥夺法;2、撤消进程法

4.进程的同步

阻止两个线程对同一共享资源进行并发访问。
对于同步代码块:synchronized(obj){ 此处就是同步代码块 }//obj 是同步监听器 str account等等可能被并发访问的共享资源部
同步方法:public synchronized void draw(double drawAmount)

转载地址:http://vorxb.baihongyu.com/

你可能感兴趣的文章
Cocos2d-x 3.2导入到Eclipse后出现The import org.cocos2dx.lib cannot be resolved错误
查看>>
Cocos2dx3.2从零开始【一】Cocos2d-x 3.2项目创建和编译,移植到Android
查看>>
Cocos2dx3.2从零开始【二】继续Cocos2dx3.2
查看>>
Cocos2dx3.2从零开始【三】继续Cocos2dx3.2的学习
查看>>
Cocos2dx3.2从零开始【四】继续。
查看>>
Unable to execute dex: Multiple dex files define 解决方法
查看>>
Cocos2dx3.2从零开始【五】
查看>>
佛祖保佑 永无BUG 永不修改
查看>>
字符画
查看>>
JS读取DropDownList中的值
查看>>
进度条例子
查看>>
DIV并排显示并换行
查看>>
Sublime Text 2中文乱码问题的解决
查看>>
C#实现无边框窗体拖动
查看>>
WordPress注册支持中文用户名的解决办法
查看>>
设置WordPress评论头像为圆角鼠标触碰后旋转效果
查看>>
WordPress:删除多说插件的版权信息
查看>>
查询表中两个条件下的数目,按三列组成表
查看>>
WinForm下禁止TextBox右键菜单
查看>>
C#_winform_DataGridView_的18种常见属性
查看>>