Java元组学习
程序员文章站
2022-07-03 12:49:42
...
在Java 中我们平时用的接口和方法 只是单一的返回某一个对象 有时候,我们需要同时返回两个不同的对象,这时候就需要用到元组数据结构(ps:自己最早接触元组 是在scala语言中 有兴趣朋友可以去看一下,也是一种函数式编程思想。)元组可以灵活的在一个方法中同时返回你想要的两个结果。不用再去构建新的代码去接受。
测试:
打印值为下;
Connected to the target VM, address: '127.0.0.1:51475', transport: 'socket'
test
1
2
3
Disconnected from the target VM, address: '127.0.0.1:51475', transport: 'socket'
看完 是不是觉得这种元组数据结构在某些地方用起来很方便呢。
public class Tuple { public static <V1, V2> Tuple2<V1, V2> of(V1 v1, V2 v2) { return new Tuple2<>(v1, v2); } public static <V1, V2, V3> Tuple3<V1, V2, V3> of(V1 v1, V2 v2, V3 v3) { return new Tuple3<>(v1, v2, v3); } }
public class Tuple2<V1, V2> { private final V1 v1; private final V2 v2; public Tuple2(V1 v1, V2 v2) { this.v1 = v1; this.v2 = v2; } public static <V1, V2> Tuple2<V1, V2> of(V1 v1, V2 v2) { return new Tuple2<>(v1, v2); } public V1 _1() { return v1; } public V2 _2() { return v2; } @Override public String toString() { return "(" + v1 + "+" + v2 + ")"; } /** * 重写hashcode * * @return 用31 可以减少hashcode值在范围内值冲突 以及31可以被JVM优化 * <p> * * 左移 << : 左边的最高位丢弃,右边补全0(把 << 左边的数据*2的移动次幂)。 * * 右移 >> : 把>>左边的数据/2的移动次幂。 * * 无符号右移 >>> : 无论最高位是0还是1,左边补齐0。 * <p> * 所以 : 31 * i = (i << 5) - i(左边 31*2=62,右边 2*2^5-2=62) - 两边相等,JVM就可以高效的进行计算啦。。。 */ @Override public int hashCode() { int result = v1.hashCode(); result = 31 * result + v2.hashCode(); return result; } /** * 重写equals 方法 */ @Override public boolean equals(Object obj) { if (this == obj) { return true; } //对象为空,或者引用地址不等 返回 false if (obj == null || getClass() != obj.getClass()) { return false; } // 值不等返回false Tuple2<?, ?> tuple2 = (Tuple2<?, ?>) obj; if (!v1.equals(tuple2.v1)) return false; return v2.equals(tuple2.v2); } }
public class Tuple3<V1,V2,V3> { private final V1 v1; private final V2 v2; private final V3 v3; public Tuple3(V1 v1, V2 v2, V3 v3) { this.v1 = v1; this.v2 = v2; this.v3 = v3; } public static <V1, V2, V3> Tuple3<V1, V2, V3> of(V1 v1, V2 v2, V3 v3) { return new Tuple3<>(v1, v2, v3); } public V1 _1() { return v1; } public V2 _2() { return v2; } public V3 _3() { return v3; } @Override public String toString() { return "(" + v1 + "," + v2 + "," + v3 + ')'; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Tuple3<?, ?, ?> tuple3 = (Tuple3<?, ?, ?>) o; if (!v1.equals(tuple3.v1)) return false; if (!v2.equals(tuple3.v2)) return false; return v3.equals(tuple3.v3); } @Override public int hashCode() { int result = v1.hashCode(); result = 31 * result + v2.hashCode(); result = 31 * result + v3.hashCode(); return result; } }
测试:
package com.stduy; import com.stduy.Tuple.Tuple2; import java.util.ArrayList; import java.util.List; import static java.lang.System.out; /** * @author zhangkun * @create 2018-12-17 10:16 AM * @desc **/ public class TupleTest { public static void main(String[] args) { Tuple2<String, List> tuple = testTuple(); out.println(tuple._1()); List<Integer> list = tuple._2(); list.stream().forEach(out::println); } public static Tuple2<String,List> testTuple(){ List<Integer> longList = new ArrayList<>(3); longList.add(1); longList.add(2); longList.add(3); return Tuple2.of("test",longList); } }
打印值为下;
Connected to the target VM, address: '127.0.0.1:51475', transport: 'socket'
test
1
2
3
Disconnected from the target VM, address: '127.0.0.1:51475', transport: 'socket'
看完 是不是觉得这种元组数据结构在某些地方用起来很方便呢。
下一篇: 各种Sensor传感器