当前位置: 首页 > 文档资料 > Guava 中文文档 >

Table

优质
小牛编辑
127浏览
2023-12-01

表表示一个特殊映射,其中可以以组合方式指定两个键以引用单个值。 它类似于创建地图地图。

接口声明 (Interface Declaration)

以下是com.google.common.collect.Table《R,C,V》界面的声明 -

@GwtCompatible
public interface Table<R,C,V>

接口方法

Sr.No方法和描述
1

Set《Table.Cell《R,C,V》》 cellSet()

返回所有行键/列键/值三元组的集合。

2

void clear()

从表中删除所有映射。

3

Map《R,V》 column(C columnKey)

返回具有给定列键的所有映射的视图。

4

Set《C》 columnKeySet()

返回一组在表中包含一个或多个值的列键。

5

Map《C,Map《R,V》》 columnMap()

返回一个视图,该视图将每个列键与从行键到值的相应映射相关联。

6

boolean contains(Object rowKey, Object columnKey)

如果表包含具有指定行和列键的映射,则返回true。

7

boolean containsColumn(Object columnKey)

如果表包含具有指定列的映射,则返回true。

8

boolean containsRow(Object rowKey)

如果表包含具有指定行键的映射,则返回true。

9

boolean containsValue(Object value)

如果表包含具有指定值的映射,则返回true。

10

boolean equals(Object obj)

将指定对象与此表进行比较以获得相等性。

11

V get(Object rowKey, Object columnKey)

返回与给定行和列键对应的值,如果不存在此类映射,则返回null。

12

int hashCode()

返回此表的哈希码。

13

boolean isEmpty()

如果表不包含映射,则返回true。

14

V put(R rowKey, C columnKey, V value)

将指定的值与指定的键关联。

15

void putAll(Table《? extends R,? extends C,? extends V》 table)

将指定表中的所有映射复制到此表。

16

V remove(Object rowKey, Object columnKey)

删除与给定键关联的映射(如果有)。

17

Map《C,V》 row(R rowKey)

返回具有给定行键的所有映射的视图。

18

Set《R》 rowKeySet()

返回一组在表中具有一个或多个值的行键。

19

Map《R,Map《C,V》》 rowMap()

返回一个视图,该视图将每个行键与从列键到值的相应映射相关联。

20

int size()

返回表中的行键/列键/值映射的数量。

21

Collection《V》 values()

返回所有值的集合,可能包含重复项。

表接口示例

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

GuavaTester.java

import 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<R,C,V> == Map<R,Map<C,V>>
      /*
      *  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<String, String, String> 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<String,String> ibmEmployees =  employeeTable.row("IBM");
      System.out.println("List of IBM Employees");
      for(Map.Entry<String, String> entry : ibmEmployees.entrySet()) {
         System.out.println("Emp Id: " + entry.getKey() + ", Name: " + entry.getValue());
      }
      //get all the unique keys of the table
      Set<String> 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<String,String> EmployerMap =  employeeTable.column("102");
      for(Map.Entry<String, String> 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