Java基础之数组队列及Java堆外内存学习笔记[图]

Java基础之数组队列及Java堆外内存学习笔记[图]
1.数组
1.1 数组基本概念:
数组是一个容器,能够存储同一数据类型的N个数据;数组是一个数据结构,是数据结构中访问速度最快的;
数组是直接经过下标进行定位;
数组是属于引用数据类型(数组名中存储的是内存首地址);数组自己只有有length属性(获取数组能存储的数据个数),可是有从Objuect父类继承的属性和方法。
1.2数组在内存中的存储:
数组在内存中是一个连续的存储空间;一维数组、二维数组....
1.3数组排序:堆排序
2.数组队列
利用数组这个数据结构,来实现多个数据的类。数组在定义的时候要定义类型和大小,定义完后不能修改(不能动态改变大小和数据类型)。
存储数据的个数是会根据实际状况进行变化,可是数组大小没法改变。
不肯定要存储的个数:
数组定义大了,数据小了,浪费空间;数组定义小了,数据多了,越界、存储不下。要知足上述两种要求,利用数组名中存储的是数组对象在堆内存中的首地址。存储数据类型,在单独某一个程序使用中是不会存在太大问题。
数组队列是否可以通用,数据类型。Object是全部类的父类:Java中全部基本数据类型都由对应一个类,其父类为Object。
若是要求数组中只能存储某一种数据类型;若是要求数组中能够存储任何数据类型。要知足上述两种要求,只能使用Java泛型。
泛型不是数据类型,是一种特殊的符号,用于泛指Java中任意一种引用类型。在编写数组队列(提供的插件类),不肯定以后要存储的数据类型,则只能使用泛型的表示。泛型在此处只是一个占位符,以后在使用中。
Java堆外内存:
1. 首先了解堆内内存on-heap memory 
这里写图片描述 
2. 定义:off-heap memory
堆外内存就是把内存对象分配在Java虚拟机的堆之外的内存。这些内存直接受操做系统管理(而不是虚拟机),咱们仨读后感(http://www.simayi.net/duhougan/2472.html)心得体会及感悟,这样作的结果就是可以在必定程度上减小垃圾回收对应用程序形成的影响。
3. 特色
一、减小了垃圾回收
由于垃圾回收会暂停其余的工做。
二、加快了复制的速度
堆内在flush到远程时,会先复制到直接内存(非堆内存),而后在发送;而堆外内存至关于省略掉了这个工做。
4. 堆外内存的管理:DirectByteBuffer
DirectByteBuffer类是在Java Heap外分配内存,对堆外内存的申请主要是经过成员变量unsafe来操做; 
ByteBuffer bb = ByteBuffer.allocateDirect(1024*1024*128);
5. 其余
System.gc使用-XX:+DisableExplicitGC能够禁掉;
经过-XX:+ExplicitGCInvokesConcurrent也能够作并行gc;
最多见的场景是RMI/NIO下的堆外内存分配等;html

相关文章
相关标签/搜索