JVM&NIO&HashMap简单问】的更多相关文章

JVM&NIO&HashMap简单问 背景:前几天在网上看到关于JVM&NIO&HashMap的一些连环炮的面试题,整理下以备不时之需. 一.JVM Java的虚拟机的面试内容主要包括GC.类加载机制和内存三大部分.如下是一个一个GC部分简单的连环炮: 问: 什么时候一个对象会被GC? 答: 当没有任何对象的引用指向该对象时 + 在下次垃圾回收周期来到时,对象才会被回收. 又问:为什么要在这种时候对象才会被GC? 答: 因为JVM会自动回收没有被引用的对象来释放空间,从而解…
深入理解NIO(一)—— NIO的简单使用及其三大组件介绍 深入理解NIO系列分为四个部分 第一个部分也就是本节为NIO的简单使用(我很少写这种新手教程,所以如果你是复习还好,应该不难理解这篇,但如果你真的是入门而且不常阅读这种文字教程可能会看不懂,我的锅,别担心,建议找点简单的视频教程什么的先看看) 第二个部分为Tomcat中对NIO的应用(本篇虽然讲Tomcat源码,但是主要讲其中NIO的部分,其他部分请移步)(如果对NIO简单使用有把握的话可以直接先看这篇) 第三个部分为NIO原理及部分源…
1:HashMap的数据结构? A:哈希表结构(链表散列:数组+链表)实现,结合数组和链表的优点.当链表长度超过8时,链表转换为红黑树. transient Node<K,V>\[\] table; 2,HashMap工作原理? HashMap底层是hash数组和单向链表实现,数组中的每个元素都是链表,有Nade内部类(实现Map.Entry接口)实现,HashMap通过put&get方法存储和获取. 存储对象时,将K/V键值传给put()方法: 1.调用hash(K)方法计算K的ha…
大家好,我是老三,"面渣逆袭"系列继续,这节我们来搞定JVM.说真的,JVM调优什么的一个程序员可能整个职业生涯都碰不到两次,但是,一旦用到的时候,那就是救命了,而且最重要的是--面试必问,所以,还能怎么办?整! 引言 1.什么是JVM? JVM--Java虚拟机,它是Java实现平台无关性的基石. Java程序运行的时候,编译器将Java文件编译成平台无关的Java字节码文件(.class),接下来对应平台JVM对字节码文件进行解释,翻译成对应平台匹配的机器指令并运行. 同时JVM也…
去面试时,hashmap总是被经常问的问题,下面总结了几道关于hashmap的问题. 1.hashmap的主要参数都有哪些? 2.hashmap的数据结构是什么样子的?自己如何实现一个hashmap? 3.hash计算规则是什么? 4.说说hashmap的存取过程? 5.说说hashmap如何处理碰撞的,或者说说它的扩容? 解答:以1.7为例,也会掺杂一些1.8的不同点. 1. 1)桶(capacity)容量,即数组长度:DEFAULT_INITIAL_CAPACITY=1<<4:默认值为16…
这是面试专题系列第五篇JVM篇. 说说JVM的内存布局? Java虚拟机主要包含几个区域: 堆:堆Java虚拟机中最大的一块内存,是线程共享的内存区域,基本上所有的对象实例数组都是在堆上分配空间.堆区细分为Yound区年轻代和Old区老年代,其中年轻代又分为Eden.S0.S1 3个部分,他们默认的比例是8:1:1的大小. 栈:栈是线程私有的内存区域,每个方法执行的时候都会在栈创建一个栈帧,方法的调用过程就对应着栈的入栈和出栈的过程.每个栈帧的结构又包含局部变量表.操作数栈.动态连接.方法返回地…
NIO基本介绍 Java NIO(New IO) 也有人称之为Java non-blocking IO 是从Java1.4版本开始引入的一个新的IO API,可以代替标准的IO API.NIO与原来的IO有同样的作用和目的,但是使用的方式完全不同,NIO支持面向缓冲区的,基于通道的IO操作.NIO将以更加高效的方式进行文件的读写操作.NIO可以理解为非阻塞IO,传统的IO的read和write只能阻塞执行,线程在读写IO期间不能干其他事情,比如调用socket.read()时,如果服务器一直没有…
哈希表也叫做散列表.在各种语言中都有hashmap的实现.其最突出的优点是查找和插入以及删除具有常数的时间复杂度 我们可以把哈希表理解为数组+链表 数组具有常数复杂度的查找,为什么呢,因为数组是在内存中连续存放,当我们索引某个位置的元素时候根据 索引值自动计算距离数组首元素起始位置的内存间隔.然而对于中间插入和中间删除元素,数组会将待插入位 置后面的原素先整体向后移动一个位置再将元素插入到待插入的位置.所以时间复杂度为O(n)对于大规模的数 组来说,开销是很大的. 然而链表正相反.由于链表是存储…
1.简介 本文是上一篇文章实践篇,在上一篇文章中,我分析了选择器 Selector 的原理.本篇文章,我们来说说 Selector 的应用,如标题所示,这里我基于 Java NIO 实现了一个简单的 HTTP 服务器.在接下来的章节中,我会详细讲解 HTTP 服务器实现的过程.另外,本文所对应的代码已经上传到 GitHub 上了,需要的自取,仓库地址为 toyhttpd.好了,废话不多说,进入正题吧. 2. 实现 本节所介绍的 HTTP 服务器是一个很简单的实现,仅支持 HTTP 协议极少的特性…
关于JVM的面试传送门:https://blog.csdn.net/shengmingqijiquan/article/details/77508471 JVM内存结构主要划分为:堆,jvm栈,本地方法栈,方法区,程序计数器 如下图所示: 堆区: 简单概述:每个Java项目都有唯一对应的一个JVM实例,每一个JVM实例又对应着一个堆区.Java堆是被当前应用所有进程所共享的,在JVM启动时就创建了.堆区的目的就是存放所有new创建实例对象和数组,由此可见堆对于当前应用来说是全局的. PS:这也就…