什么是指针压缩?如何开启和关闭指针压缩?为什么要进行指针压缩?有哪些注意的地方?

什么是指针压缩呢?

从jdk1.6开始在64位的操作系统中就JVM就支持指针压缩。

如何开启和关闭指针压缩?

jvm配置参数:UseCompressedOops,compressed--压缩、oop(ordinary object pointer)--对象指针。启用指针压缩:-XX:+UseCompressedOops(默认开启),禁止指针压缩:-XX:-UseCompressedOops

为什么要进行指针压缩?有哪些注意的地方?

1.在64位平台的HotSpot中使用32位指针(实际存储用64位),内存使用会多出1.5倍左右,使用较大指针在主内存和缓存之间移动数据,占用较大宽带,同时GC也会承受较大压力

2.为了减少64位平台下内存的消耗,启用指针压缩功能

3.在jvm中,32位地址最大支持4G内存(2的32次方),可以通过对对象指针的存入堆内存时压缩编码、取出到cpu寄存器后解码方式进行优化(对象指针在堆中是32位,在寄存器中是35位,2的35次方=32G),使得jvm只用32位地址就可以支持更大的内存配置(小于等于32G)

4.堆内存小于4G时,不需要启用指针压缩,jvm会直接去除高32位地址,即使用低虚拟地址空间

5.堆内存大于32G时,压缩指针会失效,会强制使用64位(即8字节)来对java对象寻址,这就会出现1的问题,所以堆内存不要大于32G为好

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: OSGB压缩算法是指用于压缩和解压缩Ordnance Survey National Grid(OSNG)坐标的算法。OSNG是英国测绘局(Ordnance Survey)使用的地理坐标系,用于精确定位英国的地理位置。 常见的OSGB压缩算法包括: 1. Grid Inclusion Algorithm(GIA):使用数学方法将坐标压缩到较小的字符串中,以便在数据传输过程中进行传输。 2. Two-letter Code(TLC):使用两个字母来编码每个坐标点,并使用数字来编码坐标的小数部分。 3. National Grid Reference System(NGRS):使用网格编号系统来编码坐标,使用英文字母和数字来表示每个坐标点。 4. Easting and Northing(E&N):使用坐标系的东西方向(easting)和南北方向(northing)来表示坐标。 这些算法都可以用于压缩和解压缩OSNG坐标,但在实际应用中,使用的算法可能会有所不同。 ### 回答2: OSGB压缩算法是指用来对OSGB数据进行压缩的算法。OSGB是一种用于表示地理数据的文件格式,常用于地图和GIS应用中。 目前常用的OSGB压缩算法有以下几种: 1. Deflate算法:Deflate算法是一种常用的无损压缩算法,可以对OSGB数据进行压缩。它通过移除数据中的冗余信息和利用重复的数据模式来减少文件大小。Deflate算法广泛应用于ZIP压缩格式中。 2. LZW算法:LZW算法是一种无损压缩算法,常用于GIF图像格式中。它利用字典编码技术,将连续出现的相同字节序列替换为更短的编码,从而实现压缩。LZW算法在某些情况下能够很好地压缩OSGB数据。 3. LZ77算法:LZ77算法是一种常用的无损压缩算法,常用于ZIP压缩格式和PNG图像格式中。它利用字典编码技术和滑动窗口机制,将数据中的重复片段替换为更短的指针,从而实现压缩。 4. RLE算法:RLE算法是一种简单的无损压缩算法,常用于一些简单的图像格式中。它通过统计连续出现的相同字节序列的次数,并用一个计数值代替这些序列,从而实现压缩。 这些算法在实际应用中可以根据OSGB数据的特点选择合适的压缩算法进行处理,以达到较好的压缩效果和解压缩速度。 ### 回答3: OSGB压缩算法主要有以下几种:LZ77,Huffman编码,LZW和Run Length编码。 LZ77是一种基于滑动窗口的压缩算法,通过将重复出现的数据替换为指向先前出现位置的指针来实现压缩。LZ77算法利用了数据的局部性特点,能够有效地减少数据的冗余,实现较高的压缩比。 Huffman编码是一种基于统计信息的压缩算法,通过建立字符出现频率的统计模型,并构建相应的编码表,将出现频率较高的字符用较短的编码表示,从而实现压缩。Huffman编码算法通过合理设计编码表,使得频率较高的字符使用较短的编码形式,能够进一步减少数据的冗余。 LZW算法是一种基于字典的压缩算法,通过建立一个动态字典,将出现的字符序列映射为唯一的编码,实现压缩。LZW算法不仅可以对单个字符进行编码,还可以对连续出现的字符序列进行编码,进一步提高压缩率。 Run Length编码是一种简单的压缩算法,通过将连续出现的重复字符序列替换为一个计数值和该字符的表示,实现压缩。Run Length编码算法适用于连续出现大量相同字符的情况,例如图像或音频数据中的重复值序列。 这些OSGB压缩算法在实际应用中常常结合使用,通过组合不同的压缩算法,可以实现更高效的数据压缩和解压缩

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值