发现大量Java原语集合处理

在阅读博客文章5减少Java垃圾收集开销的技巧时 ,我想起了一个名为Trove的小型Java收集库,该库“为Java提供了高速的常规和原始收集”。 我对应用Trove允许原始类型的集合而不是要求集合中的元素成为完整的引用对象的能力特别感兴趣。 我在这篇文章中会更详细地介绍Trove 。

JDK的标准集合尊重泛型,并要求对象引用为其元素,并且不允许在集合中存储基元。 甚至看起来似乎在标准JDK集合中放置基元的代码实际上也通过自动装箱将对象引用放置在集合中。 这种泛型方法的优点是能够使许多不同类型的对象使用相同的类和方法。 代价是即使可以存储更精简的基元,也需要存储完整的参考对象。

Trove库具有LPGL许可证 ,并且相对较小(不足10 MB),如“下载”页面的下一个屏幕快照所示:

troveDownloads-20151219

小型下载文件不仅包含JAR格式的必需库。 它还包含文档和源。 库JAR本身(本例中trove-3.1a1.jar )的大小约为2.5 MB。

troveJarSize

Trove易于使用的原因之一是,它在其自己的集合的API中很大程度上模仿了JDK集合的接口。 下一个代码清单演示了如何将值添加到List实现实质上是与使用JDK 7 List (在这种情况下为ArrayList)还是Trove提供的TDoubleArrayList相同的API调用。

向JDK的ArrayList和Trove的TDoubleArrayList添加元素

/*** Demonstrate standard JDK {@code ArrayList<Double>}* with some JDK 8 functionality.*/
public void demonstrateJdkArrayListForDoubles()
{final ArrayList<Double> doubles = new ArrayList<>();doubles.add(15.5);doubles.add(24.4);doubles.add(36.3);doubles.add(67.6);doubles.add(10.0);out.println("JDK ArrayList<Double>:");out.println("\tDoubles List: " + doubles);out.println("\tMaximum double: " + doubles.stream().max(Double::compare));out.println("\tMinimum double: " + doubles.stream().min(Double::compare));out.println("\tSum of doubles: " + doubles.stream().mapToDouble(Double::doubleValue).sum());
}/*** Demonstrate use of TDoubleArrayList and show how* similar using it is to using {@code ArrayList<Double>}.*/
public void demonstrateTroveArrayListForDoubles()
{// Demonstrate adding elements to TDoubleArrayList is// exactly like adding elements to ArrayList<Double>.final TDoubleArrayList doubles = new TDoubleArrayList();doubles.add(15.5);doubles.add(24.4);doubles.add(36.3);doubles.add(67.6);doubles.add(10.0);out.println("Trove TDoubleArrayList:");  // TDoubleArrayList overrides toString()out.println("\tDoubles List: " + doubles);out.println("\tMaximum double: " + doubles.max());out.println("\tMinimum double: " + doubles.min());out.println("\tSum of doubles: " + doubles.sum());
}

上面的代码清单还演示了使用数组列表的Trove实现访问双精度集合的最大值,最小值和总和是多么容易。 将这些集合写入特定原始数据类型(在这种情况下为double)的优点之一是,可以在实现中提供专门应用于该数据类型的方法。 尽管对于String的集合或任意对象的集合返回最大值,最小值和总和来说并没有TDoubleArrayList意义,但是这些方法的含义对于专门用于双精度的集合(例如TDoubleArrayList是显而易见的。 上面的清单确实指示了如何使用流使用JDK 8实现相同的功能。

当查看上面的代码时,一个细微的差异可能并不明显(由于自动装箱),这是JDK实现ArrayList存储引用Double对象,而Trove TDoubleArrayList实现存储原始double 。 Trove提供了各种数字类型的列表,集合和映射的实现,例如字节,字符,short,整数,long,float和double。

Trove提供的有趣的数据结构/集合之一是TDoubleArrayStack 。 在刚刚演示过的TDoubleArrayList的支持下, TDoubleArrayStack并未在其API中公开用于添加元素的add方法。 相反,它的方法反映了后进先出(LIFO)堆栈实现中可能期望的语义: push(double)添加, pop()访问和删除最近添加的条目,以及peek()查看最近添加的条目而不删除它。 下一个代码清单显示了此堆栈实现的应用程序。 还有其他数字数据类型的堆栈实现。

Trove的TDoubleArrayStack

/*** Demonstrate Trove's Double Array Stack.** Trove's TDoubleArrayStack allows access to its* contents via push, pop, and peek.*/
public void demonstrateTroveDoubleArrayStack()
{final TDoubleArrayStack stack = new TDoubleArrayStack();stack.push(15.5);stack.push(17.3);stack.push(16.6);stack.push(2.2);out.println("Trove Array Stack of Doubles");out.println("\tPeek: " + stack.peek() + "; After Size: " + stack.size());out.println("\tPop:  " + stack.pop() + "; After Size: " + stack.size());out.println("\tPeek: " + stack.peek() + "; After Size: " + stack.size());
}

尽管未在此处显示,但Trove在其gnu.trove.queue包中还支持Java原始类型的先进先出(FIFO)队列结构。 该软件包中的类提供了遵循队列语义的方法: offer , poll和peek 。

使用JDK集合时, java.util.Collections类提供了许多有用的功能。 Trove提供了java.util.Collections功能的子集,用于在其自己的名为gnu.trove.TCollections的类中使用基于Trove的集合。 具体来说,在撰写本文时, TCollections类为同步和未修改的Trove集合提供支持。 下一个代码清单演示了如何使用TCollections ,还演示了如何使用Trove集合,该集合面向的数据类型不是double (在这种情况下为int )和其他数据结构类型(链接列表)。

展示了TCollections和TIntLinkedList

/*** Demonstrate one of Trove's "equivalent"s of the* java.util.Collections class.*/
public void demonstrateTroveCollectionsClass()
{final TIntLinkedList integers = new TIntLinkedList();integers.add(5);integers.add(7);integers.add(3);integers.add(1);final TIntList unmodifiableIntegers = TCollections.unmodifiableList(integers);try{unmodifiableIntegers.add(15);}catch (Exception ex){out.println("\tException caught: " + ex);}
}

当希望对基于Trove的集合进行迭代时,可以通过传统的迭代器对其进行访问,如下面的代码清单所示。 尽管在此示例中,集合和关联的迭代器在long值上起作用,但是Trove为Java的其他原始数据类型提供了类似的集合和迭代器。

使用Trove迭代器迭代Trove集合

/*** Demonstrate "traditional" iteration of a* Trove collection.*/
public void demonstrateIterationWithIterator()
{final TLongHashSet longs = new TLongHashSet();longs.add(15);longs.add(6);longs.add(12);longs.add(13);longs.add(2);TLongIterator longIterator = longs.iterator();while (longIterator.hasNext()){final long longValue = longIterator.next();out.println(longValue);}
}

迭代Trove集合的另一种方法是使用Procedure 。 下面的两个代码清单对此进行了演示。 第一个清单演示了一个自定义的面向long过程的过程,第二个清单演示了将该自定义过程通过其forEach方法应用于TLongLinkedList上的迭代。

使用Trove过程迭代Trove集合

/*** Demonstrate iteration of a Trove collection* using a Procedure.*/
public void demonstrateIterationWithProcedure()
{final TLongLinkedList longs = new TLongLinkedList();longs.add(15);longs.add(6);longs.add(12);longs.add(13);longs.add(2);longs.forEach(new StandardOutputLongProcedure());
}

先前迭代示例中使用的过程实现

package dustin.examples.trove;import static java.lang.System.out;import gnu.trove.procedure.TLongProcedure;/*** Simple implementation of TLongProcedure that* iterates over Trove collection of {@code long}* values and writes those values to standard* output with one value per line.*/
public class StandardOutputLongProcedure implements TLongProcedure
{@Overridepublic boolean execute(long longValue){out.println(longValue);return true;}
}

值得注意的是Trove集合倾向于提供forEachDescending方法以及以相反顺序提供迭代。

与GNU Trove相关的其他观察

  • GNU Trove是一个提供“ Java的高速常规和原始集合”的库,不应与Trove混淆,后者是“ OpenStack的数据库即服务 ”。
  • Trove集合和数据结构的名称都以“ T”开头(对于Trove)。 实际上,除了HashingStrategy , IdentityHashingStrategy和Version之外,Trove中的所有类和接口都以“ T” 开头 。
  • Trove集合通常提供接受其基础数据类型的数组的构造函数,并提供toArray()方法以原始数组的形式提供其数据元素。
  • Trove集合通常提供显式覆盖的toString()实现,这些实现允许像JDK集合一样轻松编写各个数据元素,并且与Java数组(需要Arrays.toString()方法)不同。
  • 有关Trove的其他详细信息,请参见概述 , 常见问题解答和消息论坛 。 其他资源包括使用此Treasure Trove增强集合性能 , Java HashMap性能 , Java中的高性能库以及TROVE – Java高性能集合 。
  • Trove的Java软件包通常按数据结构类型进行组织,对于同一数据包中给定的数据结构类型,所有特定于原始类型的实现都可以进行组织。 例如,软件包的名称类似gnu.trove.list , gnu.trove.set等。
  • 因为每个Trove集合都特定于特定的原始数据类型,所以每个集合都不需要通用参数,并且没有与通用相关的问题(例如擦除)。 此方法还允许每个集合支持特定于该集合中存储的数据类型的方法。 例如,数字类型的集合可以提供sum方法,而特定于字符类型的集合可以提供grep方法。

结论

在许多常见用途中,JDK提供的集合将表现良好,并且存储对象引用可能不是问题。 但是,在某些情况下,使用Trove集合(特别是存储基元而不是对象引用)的能力可能会提供必要的优势。 随着集合变大,在集合中存储基元而不是它们的等效对象引用的优势变得更加明显。

翻译自: https://www.javacodegeeks.com/2016/01/discovering-trove-java-primitives-collection-handling.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/355630.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

51nod1244 欧拉函数之和 杜教筛

和上一题差不多&#xff0c;一个是μ*Ie&#xff0c;一个是φ*IId 稍改就得到了这题的代码 &#xff08;我会告诉你我一开始逆元算错了吗&#xff09; 1 #include <bits/stdc.h>2 #define MAX 50000003 #define MOD 10000000074 using namespace std;5 long long a,b,N;6…

java7代码示例_Java中的七种排序方式代码示例

packagebaseJava;/*** title SortMethods.java*authorDonsenChen* Date 2018年5月2日 上午10:16:03* Description*/public classSortMethods {public static voidmain(String[] args) {int[] arr { 3, 7, 9, 1, 4, 8, 2, 6, 5};binarySort(arr);bubbleSort(arr);quickSort(arr…

nginx配置多个server_Nginx基本属性配置详解

. Nginx服务的基本配置1.1 用于调试进程和定位问题的配置项是否以守护进程的方式运行nginx# 默认ondaemon on|off;是否以master/worker方式工作# 默认on&#xff0c;指定了是否以master-worker进程的方式运行&#xff0c;如果设置为off&#xff0c;那么所有的请求将只会由maste…

android-DNS服务找不到

1、重启eclipse 2、重新建立AVD 3、在建立AVD时sd卡数值不要填转载于:https://www.cnblogs.com/shouhutian/p/6838327.html

数据增长率怎么算_20年老股民告诉你5个数据可轻松算出股价是否高估

自从开通自媒体以来&#xff0c;有很多朋友问我该如何正确判断股票的合理价格呢&#xff1f;说得太专业&#xff0c;可能很多新入市的股民朋友看不懂。那有没有一种估值方法通俗易懂呢&#xff1f;说实话&#xff0c;真有点为难我了。我首先想到了最简单的PE估值法&#xff0c;…

与Selenium的集成测试

总览 我已经使用了一段时间&#xff0c;并且遇到了一些似乎可以使生活更轻松的事情。 我以为可以将其作为教程分享&#xff0c;所以我将向您介绍这些部分&#xff1a; 使用Maven设置Web项目&#xff0c;配置Selenium以在CI上作为集成测试运行 研究使用“页面对象”为网站中的…

MFC程序打开文件对话框出错的问题解决

前几天从网上下了个图像分析的mfc小程序&#xff0c;是VC6的 用VC6在本地编译生成都没问题。执行起来弹出一个未处理的错误&#xff0c;程序崩溃退出。 想起来原来遇到过打开文件对话框方面的问题&#xff0c;当时项目时间紧张未能深究。 这次要好好看下这个问题。 详细做法就是…

ad 单点登录 java 访问权限_AD 单点登录以及windows认证详细说明

上篇博客我谈到了一些关于ASP.NET Forms身份认证方面的话题&#xff0c;这次的博客将主要介绍ASP.NET Windows身份认证。Forms身份认证虽然使用广泛&#xff0c;不过&#xff0c;如果是在 Windows Active Directory 的环境中使用ASP.NET&#xff0c; 那么使用Windows身份认证也…

index加载显示servlet数据_[WEB篇]-JavaWeb基础与应用-02-Servlet开发

JavaWeb基础与应用2.Servlet开发Servlet是sun公司提供的一门用于开发动态web资源的技术。Sun公司在其API中提供了一个servlet接口&#xff0c;用户若想用发一个动态web资源(即开发一个Java程序向浏览器输出数据)&#xff0c;需要完成以下2个步骤&#xff1a;编写一个Java类&…

Linux命令之stty

用途说明 stty命令用于显示和修改终端行设置&#xff08;change and print terminal line settings&#xff09;。 常用参数 stty命令不带参数可以打印终端行设置&#xff0c;加上-a参数可以打印得更详细些。 stty size可以显示终端的大小&#xff0c;即行数和列数。 stty命令还…

本机速度文件支持的“纯” Java大数据存储

动机 所有这一切始于意识到我买不起足够大的计算机。 音频处理需要大量的内存。 Audacity是一款出色的免费音频处理器&#xff0c;它使用文件支持的存储系统对其进行管理。 这是解决此类问题的常用方法&#xff0c;在这些问题中&#xff0c;我们存储了大量信息&#xff0c;并希…

element ui后台html_GitHub上10个开源且优秀的后台管理系统UI面板

作者&#xff1a;SevDotwww.jianshu.com/p/3bc7404af887Web 开发中几乎的平台都需要一个后台管理&#xff0c;但是从零开发一套后台控制面板并不容易&#xff0c;幸运的是有很多开源免费的后台控制面板可以给开发者使用&#xff0c;那么有哪些优秀的开源免费的控制面板呢&#…

mysql 唯一记录_mysql选择唯一记录

我有以下查询&#xff1a;select * from members,subscriptionswhere members.MemberID subscriptions.MemberIDand subscriptions.Year 2009and members.ASSCID 15and subscriptions.Untildate between $2009-01-01 and 2009-12-31order by members.Memberlastname会员支付…

JAVA第七次作业

《Java技术》第七次作业 &#xff08;一&#xff09;学习总结 1.写出事件处理模型中的几个关键词&#xff0c;并通过具体代码实例说明你对事件处理模型的理解。 WindowListener&#xff1a;窗体事件&#xff0c;专门处理窗体的事件监听口&#xff0c;窗体的所有变化都可以使用此…

java时间格式转js_使用jquery或java脚本将日期时间转换为rfc3339格式

您的要求似乎微不足道&#xff0c;还有更多吗&#xff1f;这是显而易见的答案&#xff1a;function formatTimestring(s) {var b s.split(/[\\/:]/);return b[2] b[1] b[0] \T\ b[3] b[4] \00\ \Z\}alert(formatTimestring(\08/09/2010:12:00\) //20100908T120000Z);如…

输出以下图案菱形7行_春夏格子图案超流行,三木的一款格子连衣裙,带来田园少女风...

春夏搭配中&#xff0c;增添了华丽格子图案搭配&#xff0c;从经典的格子裙子&#xff0c;到衬衫裙等。根据搭配不同而成为不同风格。所以&#xff0c;这一次&#xff0c;重点介绍格子裙和长衬衫的几种种搭配。格子裙子的春夏搭配推荐LOOK&#xff1a;1 [格子褶皱裙子棕色T恤]的…

asp.net FileUpload上传文件夹并检测所有子文件

1.在FileUpload控件添加一个属性 webkitdirectory""就可以上传文件夹了 <asp:FileUpload ID"FileUpload1" runat"server" webkitdirectory"" />2.检测文件夹下所有子文件 string DirectoryName FileUpload1.PostedFile.FileNam…

使用Project Jigsaw的JDK 9 Early Access上的Eclipse IDE

几周前&#xff0c;我写了关于在Java 9上运行Eclipse Neon的文章 &#xff08;尽管&#xff0c;我在帖子标题中错误地和令人尴尬地留下了“火星”&#xff09;。 值得注意的是&#xff0c;我列出的步骤也适用于带有Project Jigsaw &#xff08;Java模块化&#xff09;构建的JDK…

火狐配置java_java selenium+firefox环境搭建

已经成功搭建的版本关系&#xff1a;FireFox45selenium3.141.59 geckodriver 0.21.0启动浏览器后空白页&#xff1a;浏览器版本太高Firefox历史版本geckodriver驱动版本https://github.com/mozilla/geckodriver/releasesselenium maven地址org.seleniumhq.seleniumselenium-ja…

arduino蜂鸣器_板卡推荐BPIUNO32 arduino 开发板,支持webduino与arduino应用

BPI:UNO32(也称为BPI-UNO32&#xff0c;被称为BPI UNO32)是一个带有Xtensa 32位LX6的单/双核心处理器的嵌入式系统的ESP32。支持Webduino和arduino的功能。BPI-UNO32使用的是esp-WROOM32&#xff0c;MCU。ESP32是一种集成2.4 GHz Wi-Fi和蓝牙双模式的单芯片解决方案。该公司的4…