java中的tuple实现

java中没有类似c#、scala中的tuple元组类,只能自己动手,丰衣足食了,见下面的代码:

Tuple 抽象类

 1 import java.util.Optional;
 2
 3 /**
 4  * Tuple元组类
 5  *
 6  * @since: 12/4/15.
 7  * @author: http://yjmyzz.cnblogs.com/
 8  */
 9 public abstract class Tuple {
10
11     public abstract <A> Optional<A> _1();
12
13     public abstract <B> Optional<B> _2();
14
15     public abstract <C> Optional<C> _3();
16
17     public abstract <D> Optional<D> _4();
18
19     public abstract <E> Optional<E> _5();
20
21     public static <A, B> Tuple of(A a, B b) {
22         return new Tuple2(a, b);
23     }
24
25     public static <A, B, C> Tuple of(A a, B b, C c) {
26         return new Tuple3(a, b, c);
27     }
28
29     public static <A, B, C, D> Tuple of(A a, B b, C c, D d) {
30         return new Tuple4(a, b, c, d);
31     }
32
33     public static <A, B, C, D, E> Tuple of(A a, B b, C c, D d, E e) {
34         return new Tuple5(a, b, c, d, e);
35     }
36
37
38     public static void main(String[] args) {
39         Tuple t2 = Tuple.of(1, "one");
40         System.out.println(t2);
41         System.out.println(t2._1().get() + "," + t2._2().get());
42
43
44         Tuple t3 = Tuple.of(1, "one", "一");
45         System.out.println(t3);
46         System.out.println(t3._1().get() + "," + t3._2().get() + "," + t3._3().get());
47
48
49         Tuple t4 = Tuple.of(1, "one", "一", "壹");
50         System.out.println(t4);
51         System.out.println(t4._1().get() + "," + t4._2().get() + "," + t4._3().get() + "," + t4._4().get());
52
53         Tuple t5 = Tuple.of(1, "one", "一", "壹", "yi");
54         System.out.println(t5);
55         System.out.println(t5._1().get() + "," + t5._2().get() + "," + t5._3().get() + "," + t5._4().get() + "," + t5._5().get());
56     }
57
58 }

Tuple2

 1 import java.util.Optional;
 2
 3 public class Tuple2<A, B> extends Tuple {
 4     private A a;
 5     private B b;
 6
 7     Tuple2(A a, B b) {
 8         this.a = a;
 9         this.b = b;
10     }
11
12     @Override
13     public Optional<A> _1() {
14         return Optional.of(a);
15     }
16
17     @Override
18     public Optional<B> _2() {
19         return Optional.of(b);
20     }
21
22     @Override
23     public <C> Optional<C> _3() {
24         return Optional.empty();
25     }
26
27     @Override
28     public <D> Optional<D> _4() {
29         return Optional.empty();
30     }
31
32     @Override
33     public <E> Optional<E> _5() {
34         return Optional.empty();
35     }
36
37     @Override
38     public String toString() {
39         return "Tuple2{" +
40                 "a=" + a +
41                 ", b=" + b +
42                 ‘}‘;
43     }
44 }

Tuple3

 1 import java.util.Optional;
 2
 3 public class Tuple3<A, B, C> extends Tuple {
 4     private A a;
 5     private B b;
 6     private C c;
 7
 8     Tuple3(A e, B t, C k) {
 9         this.a = e;
10         this.b = t;
11         this.c = k;
12     }
13
14     public Optional<A> _1() {
15         return Optional.of(a);
16     }
17
18     public Optional<B> _2() {
19         return Optional.of(b);
20     }
21
22     public Optional<C> _3() {
23         return Optional.of(c);
24     }
25
26     @Override
27     public <D> Optional<D> _4() {
28         return Optional.empty();
29     }
30
31     @Override
32     public <E> Optional<E> _5() {
33         return Optional.empty();
34     }
35
36     @Override
37     public String toString() {
38         return "Tuple3{" +
39                 "a=" + a +
40                 ", b=" + b +
41                 ", c=" + c +
42                 ‘}‘;
43     }
44 }

Tuple4

 1 import java.util.Optional;
 2
 3 public class Tuple4<A, B, C, D> extends Tuple {
 4     private A a;
 5     private B b;
 6     private C c;
 7     private D d;
 8
 9     Tuple4(A a, B b, C c, D d) {
10         this.a = a;
11         this.b = b;
12         this.c = c;
13         this.d = d;
14     }
15
16     public Optional<A> _1() {
17         return Optional.of(a);
18     }
19
20     public Optional<B> _2() {
21         return Optional.of(b);
22     }
23
24     public Optional<C> _3() {
25         return Optional.of(c);
26     }
27
28     public Optional<D> _4() {
29         return Optional.of(d);
30     }
31
32     @Override
33     public <E> Optional<E> _5() {
34         return Optional.empty();
35     }
36
37     @Override
38     public String toString() {
39         return "Tuple4{" +
40                 "a=" + a +
41                 ", b=" + b +
42                 ", c=" + c +
43                 ", d=" + d +
44                 ‘}‘;
45     }
46 }

Tuple5

 1 import java.util.Optional;
 2
 3 public class Tuple5<A, B, C, D, E> extends Tuple {
 4     private A a;
 5     private B b;
 6     private C c;
 7     private D d;
 8     private E e;
 9
10     Tuple5(A a, B b, C c, D d, E e) {
11         this.a = a;
12         this.b = b;
13         this.c = c;
14         this.d = d;
15         this.e = e;
16     }
17
18     public Optional<A> _1() {
19         return Optional.of(a);
20     }
21
22     public Optional<B> _2() {
23         return Optional.of(b);
24     }
25
26     public Optional<C> _3() {
27         return Optional.of(c);
28     }
29
30     public Optional<D> _4() {
31         return Optional.of(d);
32     }
33
34     public Optional<E> _5() {
35         return Optional.of(e);
36     }
37
38     @Override
39     public String toString() {
40         return "Tuple5{" +
41                 "a=" + a +
42                 ", b=" + b +
43                 ", c=" + c +
44                 ", d=" + d +
45                 ", e=" + e +
46                 ‘}‘;
47     }
48 }

5个元素一般情况下够用了,如果觉得不够,按这个套路自行扩展吧。

时间: 2024-11-14 04:19:10

java中的tuple实现的相关文章

Java 中的泛型详解-Java编程思想

Java中的泛型参考了C++的模板,Java的界限是Java泛型的局限. 2.简单泛型 促成泛型出现最引人注目的一个原因就是为了创造容器类. 首先看一个只能持有单个对象的类,这个类可以明确指定其持有的对象的类型 class Holder1 { private Circle a; public Holder1(Circle a) { this.a = a; } Circle get() { return a; } } 上面的类的可重用性不怎么样,无法持有其他类型的任何对象,下面通过持有Object

关于Java中多维数组的内存结构分析

基本概念 本文主要针对JVM中关于一维数组和二维数组的内存模型分析.验证.讨论![仅供参考]. 1.概念模型 1)一维数组 int arr[] = new int[3]; 2)二维数组 int[ ][ ] arr = new int[3][ ]; arr[0] = new int[3]; arr[1] = new int[5]; arr[2] = new int[4]; 3)Java中的对象(本章节主要分析和数组相关的内容,关于Java对象的Memory结构会在以后说明!) class A {

java中的三元运算符详解

最近在带领实习生中遇到很多新手问与三元运算符有关的java题目,多数为代码结果题,少数为应用题.鉴于很多资料上对于java三元运算的讲解过于简单,网上的资料与题目也不是很完善,对于结果答案分析不一,故在此总结,当然仅为个人观点,水平有限,不足之处,还请大家多多指出,互相交流学习. 什么是java三元运算符呢?无疑其操作元有三个,第一个是条件表达式,剩余两个为值,条件表达式为真时运算取第一个值,为假时取第二个值. 其示例代码如下:boolean a = 20 < 45 ? true : false

java中BigDecimal的学习

干着java的活,但是看的都是一些偏底层的东西(或者我根本就没有看),有点荒废了java的学习. 最近一直在用到一个类是BigDecimal,但都是模棱两可地在那儿用,并没有深入研究这个类的细节,感觉不能再拖了. BigDecimal,从名字来看就是进行大数运算的,不光这样,还广泛用于小数的精确运算. 当你接触到和钱有关的计算的时候,这个类还是很有用滴. 先来看一个例子 1 package com.tuhooo.bigdecimal; 2 3 /** 4 * Created by tuhooo

Java 中几个重要的关键字

Java中的关键字特别多,大致如下: 访问控制 private protected public 类,方法和变量修饰符 abstract class extends final implements interface native new static strictfp synchronized transient volatile 程序控制 break continue return do while if else for instanceof switch case default 异常

深入剖析Java中的装箱和拆箱

阅读目录 一.什么是装箱?什么是拆箱?二.装箱和拆箱是如何实现的三.面试中相关的问题 自动装箱和拆箱问题是Java中一个老生常谈的问题了,今天我们就来一些看一下装箱和拆箱中的若干问题.本文先讲述装箱和拆箱最基本的东西,再来看一下面试笔试中经常遇到的与装箱.拆箱相关的问题. 回到顶部 一.什么是装箱?什么是拆箱? 我们知道 Java为每种基本数据类型都提供了对应的包装器类型,至于为什么会为每种基本数据类型提供包装器类型在此不进行阐述,有兴趣的朋友可以查阅相关资料.在Java SE5之前,如果要生成

JAVA中只有值传递

今天,我在一本面试书上看到了关于java的一个参数传递的问题: 写道 java中对象作为参数传递给一个方法,到底是值传递,还是引用传递? 我毫无疑问的回答:"引用传递!",并且还觉得自己对java的这一特性很是熟悉! 结果发现,我错了! 答案是: 值传递!Java中只有按值传递,没有按引用传递! 回家后我就迫不及待地查询了这个问题,觉得自己对java这么基础的问题都搞错实在太丢人! 综合网上的描述,我大概了解了是怎么回事,现在整理如下,如有不对之处望大神提出! 先来看一个作为程序员都熟

Java中如何优雅正确的终止线程

Java中终止线程的方式主要有三种: 1.使用stop()方法,已被弃用.原因是:stop()是立即终止,会导致一些数据被到处理一部分就会被终止,而用户并不知道哪些数据被处理,哪些没有被处理,产生了不完整的"残疾"数据,不符合完整性,所以被废弃.So, forget it! 2.使用volatile标志位 看一个简单的例子: 首先,实现一个Runnable接口,在其中定义volatile标志位,在run()方法中使用标志位控制程序运行 public class MyRunnable i

Java中I/O流之数据流

Java 中的数据流: 对于某问题:将一个 long 类型的数据写到文件中,有办法吗?    转字符串 → 通过 getbytes() 写进去,费劲,而且在此过程中 long 类型的数需要不断地转换. 现在,Java 中的数据流能够很好的解决这个问题(不需要转换,直接写进去) 1. DataInputStream 与 DataOutputStream 分别继承自 InputStream.OutputStream, 它属于处理流,需要分别套接在 InputStream.OutputStream 类