一:简答题(30)
1:数据库以及线程发生死锁的原理及必要条件,如何避免死锁
答:
产生死锁的原因主要是:
(1) 因为系统资源不足。
(2) 进程运行推进的顺序不合适。
(3) 资源分配不当等。
产生死锁的四个必要条件:
(1)互斥条件:一个资源每次只能被一个进程使用。
(2)请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
(3)不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。
(4)循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。
避免死锁:
死锁的预防是通过破坏产生条件来阻止死锁的产生,但这种方法破坏了系统的并行
性和并发性。
死锁产生的前三个条件是死锁产生的必要条件,也就是说要产生死锁必须具备的条
件,而不是存在这 3 个条件就一定产生死锁,那么只要在逻辑上回避了第四个条件就可
以避免死锁。
避免死锁采用的是允许前三个条件存在,但通过合理的资源分配算法来确保永远不
会形成环形等待的封闭进程链,从而避免死锁。该方法支持多个进程的并行执行,为了
避免死锁,系统动态的确定是否分配一个资源给请求的进程。
预防死锁:具体的做法是破坏产生死锁的四个必要条件之一
2:面向对象的三个基本元素,五个基本原则
答:
三个基本元素:
封装
继承
多态
五个基本原则:
单一职责原则(Single-Resposibility Principle) :一个类,最好只做一件事,只有一个
引起它的变化。单一职责原则可以看做是低耦合、高内聚在面向对象原则上的引申,将
职责定义为引起变化的原因,以提高内聚性来减少引起变化的原因。
开放封闭原则(Open-Closed principle) :软件实体应该是可扩展的,而不可修改的。
也就是,对扩展开放,对修改封闭的。
Liskov 替换原则(Liskov-Substituion Principle):子类必须能够替换其基类。这一思
想体现为对继承机制的约束规范,只有子类能够替换基类时,才能保证系统在运行期内
识别子类,这是保证继承复用的基础。
依赖倒置原则(Dependecy-Inversion Principle):依赖于抽象。具体而言就是高层模
块不依赖于底层模块,二者都同依赖于抽象;抽象不依赖于具体,具体依赖于抽象。
接口隔离原则(Interface-Segregation Principle):使用多个小的专门的接口,而不要
使用一个大的总接口。
3:windows 内存管理的机制以及优缺点
答:
分页存储管理基本思想:
用户程序的地址空间被划分成若干固定大小的区域,称为“页”,相应地,内存空
间分成若干个物理块,页和块的大小相等。可将用户程序的任一页放在内存的任一块中,
实现了离散分配。
分段存储管理基本思想:
将用户程序地址空间分成若干个大小不等的段,每段可以定义一组相对完整的逻辑
信息。存储分配时,以段为单位,段与段在内存中可以不相邻接,也实现了离散分配。
段页式存储管理基本思想:
分页系统能有效地提高内存的利用率,而分段系统能反映程序的逻辑结构,便于段
的共享与保护,将分页与分段两种存储方式结合起来,就形成了段页式存储管理方式。
在段页式存储管理系统中,作业的地址空间首先被分成若干个逻辑分段,每段都有
自己的段号,然后再将每段分成若干个大小相等的页。对于主存空间也分成大小相等的
页,主存的分配以页为单位。
段页式系统中,作业的地址结构包含三部分的内容:段号 页号 页内位
移量
程序员按照分段系统的地址结构将地址分为段号与段内位移量,地址变换机构将段
内位移量分解为页号和页内位移量。
为实现段页式存储管理,系统应为每个进程设置一个段表,包括每段的段号,该段
的页表始址和页表长度。每个段有自己的页表,记录段中的每一页的页号和存放在主存
中的物理块号.
- 浏览: 526482 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (605)
- JAVA笔霸 (20)
- JAVA面霸 (27)
- MySQL面 (21)
- LINUX面 (12)
- 并发面霸 (41)
- 架构面霸 (19)
- 综合面霸 (10)
- Spring面 (12)
- Dubbo面 (13)
- RabbitMQ面 (8)
- Kafka面 (8)
- zk面霸 (5)
- Netty面 (8)
- 网络面霸 (7)
- JVM面霸 (12)
- Cloud面 (7)
- Spring核面 (4)
- 设计模式 (22)
- JAVA核面 (4)
- 打好基础 (18)
- Redis面 (9)
- JAVA (28)
- Spring (18)
- LINUX (21)
- MySQL (43)
- Nginx (8)
- 架构 (15)
- 本地环境 (25)
- 安装配置 (4)
- 计算机组成 (1)
- 未分类 (20)
- ES (15)
- Code (24)
- 芋道面 (3)
- 多线程并发编程 (4)
- 理解IO (3)
- 原理机制 (5)
- TCP/IP/HTTP (4)
- Maven (7)
- MQ (3)
- 面试经历 (2)
- ES组件 (2)
- Spring基础 (3)
- Kafka现场问题支持 (1)
- Redis客户端 (5)
最新评论
发表评论
-
MySQL优化
2019-10-19 00:16 239http://mp.weixin.qq.com/s? ... -
MySQL索引
2019-10-19 00:16 164MySQL索引详解 http://shanks.l ... -
改数据库结构工具
2017-07-03 20:22 177改数据库结构工具 工具的解决办法思路是,在原表中创建几个触 ... -
MySQL字符串函数:字符串截取
2017-01-13 14:16 440MySQL字符串函数:字符串截取 http://justd ... -
sql之left join、right join、inner join的区别
2016-12-12 20:29 288sql之left join、right join ... -
mysql查询语句select-子查询
2016-12-12 20:30 343mysql查询语句select-子查询 select ... -
mysql innodb_lock
2016-11-11 11:38 491SHOW VARIABLES LIKE '%innodb_l ... -
数据库SQL优化大总结之 百万级数据库优化方案
2016-10-28 15:57 324数据库SQL优化大总结之 百万级数据库优化方案 -
MySQL优化
2016-09-15 07:33 422一、查询性能优化 重构查询方式 1、一个复杂查询还是多个 ... -
MySQL数据库优化
2016-06-16 09:21 4591、mysql 数据库优化 2、重复插入问 ... -
mysql什么情况下删除数据会释放空间
2016-06-15 14:27 355mysql什么情况下删除数据会释放空间 http://c ... -
MySQL 对于千万级的大表要怎么优化?
2016-06-15 14:26 535MySQL 对于千万级的大表要怎么优化? https:/ ... -
MySQL性能优化的最佳20+条经验
2016-06-15 14:26 413MySQL性能优化的最佳20+条经验 http://co ... -
MySQL 性能优化的最佳20多条经验分享
2016-06-08 08:44 268MySQL 性能优化的最佳20多条经验分享 http:/ ... -
MySQL SQL语句优化的10条建议
2016-06-07 08:40 359MySQL SQL语句优化的10条建议 http://w ... -
数据库SQL优化大总结之 百万级数据库优化方案
2016-06-07 08:09 477数据库SQL优化大总结之 百万级数据库优化方案 http ... -
MYSQL知识点汇聚
2015-07-26 14:26 343MySQL社区版下载地址: ... -
数据库事务隔离级别
2014-04-15 09:06 592学习笔记,转自:http://singo107.iteye ... -
Oracle笔试题
2013-09-23 22:25 525学习笔记,转自:http://blog.sina.com. ... -
数据库水平切分的实现原理解析
2013-08-04 19:17 620学习笔记,转自:http://www.iteye.com/ ...
相关推荐
通过观察、分析实验现象,深入理解线程及线程在调度执行和内存空间等方面的特点,并掌握线程与进程的区别。
SQLServer数据库死锁介绍,以及使用独立的事务模拟死锁的产生。
明白死锁产生的原因,在程序中演示死锁产生并从而实现多线程陈旭解决死锁(deadlock)这一类问题。
解决死锁问题的三种方法:预防死锁,检测死锁及避免死锁。
检测线程死锁,告诉你如何检测线程死锁,学习一下吧
分布式课堂上分享讲的ppt,简要介绍了死锁检测的基本概念,以及分布式数据库几种常见的死锁检测算法。
基于java的开发源码-多线程程序死锁检查 JCarder.zip 基于java的开发源码-多线程程序死锁检查 JCarder.zip 基于java的开发源码-多线程程序死锁检查 JCarder.zip 基于java的开发源码-多线程程序死锁检查 JCarder.zip ...
有简单的控制台例子理解线程死锁的概念。并且理解线程是轮换CPU时间片的。
死锁的4个必要条件 和3个原因死锁的4个必要条件 和3个原因
数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁
数据库死锁,阻塞查询,杀死死锁,阻塞进程
分布式数据库系统中死锁避免策略的选择,吴德州 ,武君胜, 提出了分析死锁工作的等待图的一种优化――带时戳的资源分配图,同时对分布式数据库系统中的死锁避免的两种方案通过例证给出了��
java多线程死锁预防机制研究,java多线程死锁预防机制研究
实测有效的一个c++检测线程死锁的解决方法(实现和测试代码) 原创实测有效的一个c++检测线程死锁的解决方法,已应用于项目,实测有效 原创文章地址:https://blog.csdn.net/liaozhilong88/article/details/80354414...
数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁数据库死锁
今天小编就为大家分享一篇关于Java多线程产生死锁的必要条件,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
Java多线程程序死锁检查 JCarder
java多线程及死锁
数据库 死锁的解决 其实所有的死锁最深层的原因就是一个:资源竞争 表现一: 一个用户A 访问表A(锁住了表A),然后又访问表B 另一个用户B 访问表B(锁住了表B),然后企图访问表A 这时用户A由于用户B已经锁住表B,它...
用eclipse写个简单的程序实现线程的调度问题 死锁避免