介绍java中Pair

https://blog.csdn.net/neweastsun/article/details/80294811

项目中用到了Pair,之前没接触过,百度了一下,资料比较少,先记个笔记,日后完善

介绍java中Pair

在这篇文章中,我们讨论了一个非常有用的编程概念,配对(Pair)。配对提供了一种方便方式来处理简单的键值关联,当我们想从方法返回两个值时特别有用。

在核心Java库中可以使用配对(Pair)的实现。除此之外,某些第三方库,比如Apache Commons和Vavr,已经在各自的api中公开了这个功能。

核心java配对实现

Pair类

Pair类在javafx.util 包中,类构造函数有两个参数,键及对应值:

    Pair<Integer, String> pair = new Pair<>(1, "One");
    Integer key = pair.getKey();
    String value = pair.getValue();
  • 1
  • 2
  • 3

示例描述使用Pair类实现简单Integer到String的映射。示例中getKey方法返回key对象,getValue方法返回对应值对象。

AbstractMap.SimpleEntry 和 AbstractMap.SimpleImmutableEntry

SimpleEntry定义在抽象类AbstractMap里面,其构造方法与Pair类似:

    AbstractMap.SimpleEntry<Integer, String> entry 
      = new AbstractMap.SimpleEntry<>(1, "one");
    Integer key = entry.getKey();
    String value = entry.getValue();
  • 1
  • 2
  • 3
  • 4

其键和值可以通过标准的getter和setter方法获得。

另外AbstractMap 类还包含一个嵌套类,表示不可变配对:SimpleImmutableEntry 类。

    AbstractMap.SimpleImmutableEntry<Integer, String> entry
      = new AbstractMap.SimpleImmutableEntry<>(1, "one");
  • 1
  • 2

应用方式与可变的配对一样,除了配置的值不能修改,尝试修改会抛出UnsupportedOperationException异常。

Apache Commons

在Apache Commons库中,org.apache.commons.lang3.tuple 包中提供Pair抽象类,不能被直接实例化。 
其有两个子类,分别代表可变与不可变配对:ImmutablePair 和 MutablePair。两者都实现了访问key/value以及setter和getter方法:

    ImmutablePair<Integer, String> pair = new ImmutablePair<>(2, "Two");
    Integer key = pair.getKey();
    String value = pair.getValue();
  • 1
  • 2
  • 3

尝试在ImmutablePair 执行setValue方法,会抛出UnsupportedOperationException异常。但在可变配对上执行完全正常:

    Pair<Integer, String> pair = new MutablePair<>(3, "Three");
    pair.setValue("New Three");
  • 1
  • 2

Vavr库

Vavr库中不可变的Tuple2类提供配对功能:

    Tuple2<Integer, String> pair = new Tuple2<>(4, "Four");
    Integer key = pair._1();
    String value = pair._2();
  • 1
  • 2
  • 3

在这个实现中,创建对象后不能修改,所以更新方法返回改变后的新实例:

    tuplePair = pair.update2("New Four");
  • 1

总结

本文讨论java配对概念,并通过实例展示了其不同的实现,核心java及第三方提供实现。

展开阅读全文

百度之星H题pairpair!!!

05-29

描述rn馅饼同学是一个在百度工作,做用户请求(query)分析的同学,他在用户请求中经常会遇到一些很奇葩的词汇。在比方说“johnsonjohnson”、“duckduck”,这些词汇虽然看起来是一些词汇的单纯重复,但是往往都是一些特殊品牌的词汇,不能被拆分开。为了侦测出这种词的存在,你今天需要完成我给出的这个任务——“找出用户请求中循环节最多的子串”。rnrn输入rn输入数据包括多组,每组为一个全部由小写字母组成的不含空格的用户请求(字符串),占一行。用户请求的长度不大于100,000。rn最后一行输入为#,作为结束的标志。rn输出rn对于每组输入,先输出这个组的编号(第n组就是输出“Case n:”);然后输出这组用户请求中循环节最多的子串。如果一个用户请求中有两个循环节数相同的子串,请选择那个字典序最小的。rn样例输入rnilovejohnsonjohnsonverymuchrnduckduckgornaaabbbcccisagoodcompanyrn#rn样例输出rnCase 1: johnsonjohnsonrnCase 2: duckduckrnCase 3: aaarn*************************************************************rn以下是我的代码:rn[code=C/C++]rn#include rn#include rn#includern#includernusing namespace std;rnrnpair fun(const string &str)rnrnvector substrs;rnint maxcount=1,count=1;rnstring sub;rnint i,len=str.length();rnfor(i=0;imaxcount) //maxcount 记录所有遍历中的最大连续子串出现的次数rn rn maxcount=count;rn sub=substrs[i].substr(0, j-i);rn rn else if(count==maxcount&&strncmp(sub.c_str(), substrs[i].c_str(), count)>0)rn rn maxcount=count;rn sub=substrs[i].substr(0, j-i);rn rn rn rnrnrnif(sub=="\0")rn rn sub=substrs[0];rn char ch='z';rn for(int k=0;k返回rnrnint main()rnrn int i=1;rnpair result;rnstring str;rnwhile(getline(cin,str)&&str!="#")rnrn cout<<"Case "<, std::allocator > > fun(const std::stringrn求大神解答。。。 论坛

没有更多推荐了,返回首页