java guava table_Guava Table接口

全屏

Table代表一个特殊的映射,其中两个键可以在组合的方式被指定为单个值。它类似于创建映射的映射。

接口声明

以下是 com.google.common.collect.Table 接口的声明:@GwtCompatiblepublic interface Table

接口方法S.N.方法 & 描述

1Set

> cellSet()返回集合中的所有行键/列键/值三元组。

2void clear()从表中删除所有映射。

3Map column(C columnKey)返回在给定列键的所有映射的视图。

4Set columnKeySet()返回一组具有表中的一个或多个值的列键。

5Map> columnMap()返回关联的每一列键与行键对应的映射值的视图。

6boolean contains(Object rowKey, Object columnKey)返回true,如果表中包含与指定的行和列键的映射。

7boolean containsColumn(Object columnKey)返回true,如果表中包含与指定列的映射。

8boolean containsRow(Object rowKey)返回true,如果表中包含与指定的行键的映射关系。

9boolean containsValue(Object value)返回true,如果表中包含具有指定值的映射。

10boolean equals(Object obj)比较指定对象与此表是否相等。

11V get(Object rowKey, Object columnKey)返回对应于给定的行和列键,如果没有这样的映射存在值,返回null。

12int hashCode()返回此表中的哈希码。

13boolean isEmpty()返回true,如果表中没有映射。

14V put(R rowKey, C columnKey, V value)关联指定值与指定键。

15void putAll(Table extends R,? extends C,? extends V> table)复制从指定的表中的所有映射到这个表。

16V remove(Object rowKey, Object columnKey)如果有的话,使用给定键相关联删除的映射。

17Map row(R rowKey)返回包含给定行键的所有映射的视图。

18Set rowKeySet()返回一组行键具有在表中的一个或多个值。

19Map> rowMap()返回关联的每一行按键与键列对应的映射值的视图。

20int size()返回行键/列键/表中的值映射关系的数量。

21Collection values()返回所有值,其中可能包含重复的集合。

Table 例子

选择使用任何编辑器创建以下java程序在 C:/> Guava

GuavaTester.javaimport java.util.Map;

import java.util.Set;

import com.google.common.collect.HashBasedTable;

import com.google.common.collect.Table;

public class GuavaTester {

public static void main(String args[]){

//Table == Map>

/*

*  Company: IBM, Microsoft, TCS

*  IBM -> {101:Mahesh, 102:Ramesh, 103:Suresh}

*  Microsoft -> {101:Sohan, 102:Mohan, 103:Rohan }

*  TCS -> {101:Ram, 102: Shyam, 103: Sunil }

*

* */

//create a table

Table employeeTable = HashBasedTable.create();

//initialize the table with employee details

employeeTable.put("IBM", "101","Mahesh");

employeeTable.put("IBM", "102","Ramesh");

employeeTable.put("IBM", "103","Suresh");

employeeTable.put("Microsoft", "111","Sohan");

employeeTable.put("Microsoft", "112","Mohan");

employeeTable.put("Microsoft", "113","Rohan");

employeeTable.put("TCS", "121","Ram");

employeeTable.put("TCS", "122","Shyam");

employeeTable.put("TCS", "123","Sunil");

//get Map corresponding to IBM

Map ibmEmployees =  employeeTable.row("IBM");

System.out.println("List of IBM Employees");

for(Map.Entry entry : ibmEmployees.entrySet()){

System.out.println("Emp Id: " + entry.getKey() + ", Name: " + entry.getValue());

}

//get all the unique keys of the table

Set employers = employeeTable.rowKeySet();

System.out.print("Employers: ");

for(String employer: employers){

System.out.print(employer + " ");

}

System.out.println();

//get a Map corresponding to 102

Map EmployerMap =  employeeTable.column("102");

for(Map.Entry entry : EmployerMap.entrySet()){

System.out.println("Employer: " + entry.getKey() + ", Name: " + entry.getValue());

}

}

}

验证结果

使用javac编译器编译如下类C:\Guava>javac GuavaTester.java

现在运行GuavaTester看到的结果C:\Guava>java GuavaTester

看到结果。List of IBM Employees

Emp Id: 102, Name: Ramesh

Emp Id: 101, Name: Mahesh

Emp Id: 103, Name: Suresh

Employers: IBM TCS Microsoft

Employer: IBM, Name: Ramesh

分享到:

0评论

14487a65ea137d8f9ac97cdce44a0324.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值