Table和HashBasedTable的使用案例


1.普通使用

复制代码
package org.example.testhashbasedtable;

import com.google.common.collect.HashBasedTable;
import com.google.common.collect.Table;

import java.util.Map;

public class TestHashBasedTable {
    public static void main(String[] args) {
        Table<String, Integer, Float> table = HashBasedTable.create();

        table.put("a", 1, 1.1f);
        table.put("a", 2, 2.2f);


        System.out.println(table.row("a"));
        System.out.println(table.column(2));
        System.out.println(table.row("b"));
        System.out.println(table.column(1));

        Map<String, Float> column = table.column(1);

    }
}

/*
{1=1.1, 2=2.2}
{a=2.2}
{}
{a=1.1}

感悟:通过r或者c进行查找,得到的是一个包含其它2个字段的map
 */

2.putAll 和 遍历

复制代码
package org.example.testhashbasedtable;

import com.google.common.collect.HashBasedTable;
import com.google.common.collect.Table;

public class TestHashBasedTable {
    public static void main(String[] args) {
        // 数据源1
        Table<String, Integer, Float> table = HashBasedTable.create();

        table.put("a", 1, 1.1f);
        table.put("a", 2, 2.2f);

        // 数据源2
        Table<String, Integer, Float> table2 = HashBasedTable.create();
        table2.put("a", 11, 1.1f);
        table2.put("aa", 2, 2.2f);

        // 数据源1添加到数据源2中
        table2.putAll(table);

        System.out.println(table2);

        // 遍历所有的条目
        for (Table.Cell<String, Integer, Float> cell : table2.cellSet()) {
            System.out.println(cell.getRowKey() + "  " + cell.getColumnKey() + " " + cell.getValue());
        }
    }
}

/*
{a={11=1.1, 1=1.1, 2=2.2}, aa={2=2.2}}
a  11 1.1
a  1 1.1
a  2 2.2
aa  2 2.2

 */

行、列、值 就是excel中的表格的抽象。

3.putAll的话,相同行列的是会被覆盖。相当于2个Excel表的融合。

复制代码
package org.example.testhashbasedtable;

import com.google.common.collect.HashBasedTable;
import com.google.common.collect.Sets;
import com.google.common.collect.Table;

import java.util.Set;

public class Test2 {
    public static void main(String[] args) {
        // table1
        Table<Integer, Integer, Set<Integer>> table = HashBasedTable.create();
        table.put(1, 2, Sets.newHashSet(4, 5, 6));

        // table2
        Table<Integer, Integer, Set<Integer>> table2 = HashBasedTable.create();
        table2.put(1, 2, Sets.newHashSet(6, 7, 8));

        // 把table2加到table1中
        table.putAll(table2);

        // 发现相同行列的肯定是被覆盖了
        System.out.println(table);
    }
}

/*
{1={2=[8, 6, 7]}}
 */
相关推荐
时空无限6 分钟前
Java Buildpack Reference
java·开发语言
爱笑的眼睛111 小时前
超越剪枝与量化:下一代AI模型压缩工具的技术演进与实践
java·人工智能·python·ai
阿里云云原生1 小时前
Android App 崩溃排查指南:阿里云 RUM 如何让你快速从告警到定位根因?
android·java
历程里程碑1 小时前
C++ 9 stack_queue:数据结构的核心奥秘
java·开发语言·数据结构·c++·windows·笔记·算法
醇氧1 小时前
【Windows】从守护到终结:解析一个 Java 服务的优雅停止脚本
java·开发语言·windows
努力发光的程序员1 小时前
互联网大厂Java求职面试实录
java·jvm·线程池·多线程·hashmap·juc·arraylist
小鹿学程序1 小时前
FileZilla连接到虚拟机
java·服务器·开发语言
Haooog2 小时前
Docker面试题(不定时更新)
java·docker·面试
feathered-feathered2 小时前
Redis基础知识+RDB+AOF(面试)
java·数据库·redis·分布式·后端·中间件·面试
毕设源码-赖学姐2 小时前
【开题答辩全过程】以 高校排课系统的优化设计与实现为例,包含答辩的问题和答案
java·eclipse