Table of Contents
ToggleJava LinkedHashSet Methods
實作集合框架的 Set 接口,繼承 HashSet 實現可調整大小集合的功能,循環訪問時,元素會依新增時的的順序傳回值,使用鏈結節點來存儲元素,可以隨時增加或刪除元素,保證集合新增時的順序,實作集合框架的 Set 接口,LinkedHashSet Java Methods 介紹常見的 add 、 remove 、 clear 、 size 等方法,了解 Set 的不同操作和方法,本篇增加了範例,並透過單元測試來驗證產出結果。
檔案目錄
./
+- src
+- test
| +- org
| +- ruoxue
| +- java_147
| +- set
| +- linkedhashset
| +- LinkedHashSetMethodsTest.java
單元測試
LinkedHashSet Java Methods 提供新增、刪除等操作 Set 中的元素。
add
建立 Fruit 物件,覆寫 equals 、 hashCode 提供給集合比較使用,建立一個 LinkedHashSet ,增加三個元素。
@NoArgsConstructor
@Getter
@Setter
@Builder
public static class Fruit {
private String name;
private double quantity;
private int type;
public Fruit(String name, double quantity, int type) {
this.name = name;
this.quantity = quantity;
this.type = type;
}
public String toString() {
ToStringBuilder builder = new ToStringBuilder(this, ToStringStyle.JSON_STYLE);
builder.appendSuper(super.toString());
builder.append("name", name);
builder.append("quantity", quantity);
builder.append("type", type);
return builder.toString();
}
public boolean equals(Object object) {
if (!(object instanceof Fruit)) {
return false;
}
if (this == object) {
return true;
}
Fruit other = (Fruit) object;
return new EqualsBuilder().append(getName(), other.getName()).isEquals();
}
public int hashCode() {
return new HashCodeBuilder().append(getName()).toHashCode();
}
}
@Test
public void add() {
int expectedSize = 3;
Set<Fruit> set = new LinkedHashSet<>();
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
System.out.println(set);
assertEquals(expectedSize, set.size());
}
[{"name":"Longan","quantity":1.0,"type":1}, {"name":"Tomato","quantity":2.0,"type":1}, {"name":"Pear","quantity":3.0,"type":1}]
addAll
LinkedHashSet Java Methods 建立兩個 LinkedHashSet ,內各有三個元素,合併成為一個 Set 。
@Test
public void addAll() {
int expectedSize = 6;
Set<Fruit> set = new LinkedHashSet<>();
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
Set<Fruit> set2 = new LinkedHashSet<>();
set.add(new Fruit("Grape", 4, 1));
set.add(new Fruit("Lemon", 5, 1));
set.add(new Fruit("Mango", 6, 1));
set.addAll(set2);
System.out.println(set);
assertEquals(expectedSize, set.size());
}
[{"name":"Longan","quantity":1.0,"type":1}, {"name":"Tomato","quantity":2.0,"type":1}, {"name":"Pear","quantity":3.0,"type":1}, {"name":"Grape","quantity":4.0,"type":1}, {"name":"Lemon","quantity":5.0,"type":1}, {"name":"Mango","quantity":6.0,"type":1}]
remove
LinkedHashSet Methods Java 建立一個 LinkedHashSet ,內有三個元素,刪除指定元素。
@Test
public void remove() {
int expectedSize = 2;
Set<Fruit> set = new LinkedHashSet<>();
Fruit fruit = new Fruit("Longan", 1, 1);
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
set.remove(fruit);
System.out.println(set);
assertEquals(expectedSize, set.size());
}
[{"name":"Tomato","quantity":2.0,"type":1}, {"name":"Pear","quantity":3.0,"type":1}]
removeAll
LinkedHashSet Methods Java 建立一個 LinkedHashSet ,內有三個元素,刪除來自另一個 Set 中的元素。
@Test
public void removeAll() {
int expectedSize = 1;
Set<Fruit> set = new LinkedHashSet<>();
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
Set<Fruit> set2 = new LinkedHashSet<>();
set2.add(new Fruit("Longan", 1, 1));
set2.add(new Fruit("Tomato", 2, 1));
set2.add(new Fruit("Mango", 4, 1));
set.removeAll(set2);
System.out.println(set);
assertEquals(expectedSize, set.size());
}
[{"name":"Pear","quantity":3.0,"type":1}]
clear
LinkedHashSet Methods Java 建立一個 LinkedHashSet ,內有三個元素,刪除所有元素。
@Test
public void clear() {
int expectedSize = 0;
Set<Fruit> set = new LinkedHashSet<>();
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
set.clear();
System.out.println(set);
assertEquals(expectedSize, set.size());
}
[]
size
LinkedHashSet Methods in Java 建立一個 LinkedHashSet ,內有三個元素,取得集合大小。
@Test
public void size() {
int expectedSize = 3;
Set<Fruit> set = new LinkedHashSet<>();
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
System.out.println(set.size());
assertEquals(expectedSize, set.size());
}
3
isEmpty
LinkedHashSet Methods in Java 建立一個 LinkedHashSet ,檢查是否為空 Set 。
@Test
public void isEmpty() {
Set<Fruit> set = new LinkedHashSet<>();
System.out.println(set.isEmpty());
assertTrue(set.isEmpty());
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
System.out.println(set.isEmpty());
assertFalse(set.isEmpty());
}
true
false
LinkedHashSetMethodsTest.java
LinkedHashSet Methods Java 新增單元測試,驗證是否符合預期。
package org.ruoxue.java_147.set.linkedhashset;
import static org.junit.Assert.*;
import java.util.LinkedHashSet;
import java.util.Set;
import org.apache.commons.lang3.builder.EqualsBuilder;
import org.apache.commons.lang3.builder.HashCodeBuilder;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.commons.lang3.builder.ToStringStyle;
import org.junit.Test;
import lombok.Builder;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
public class LinkedHashSetMethodsTest {
@NoArgsConstructor
@Getter
@Setter
@Builder
public static class Fruit {
private String name;
private double quantity;
private int type;
public Fruit(String name, double quantity, int type) {
this.name = name;
this.quantity = quantity;
this.type = type;
}
public String toString() {
ToStringBuilder builder = new ToStringBuilder(this, ToStringStyle.JSON_STYLE);
builder.appendSuper(super.toString());
builder.append("name", name);
builder.append("quantity", quantity);
builder.append("type", type);
return builder.toString();
}
public boolean equals(Object object) {
if (!(object instanceof Fruit)) {
return false;
}
if (this == object) {
return true;
}
Fruit other = (Fruit) object;
return new EqualsBuilder().append(getName(), other.getName()).isEquals();
}
public int hashCode() {
return new HashCodeBuilder().append(getName()).toHashCode();
}
}
@Test
public void add() {
int expectedSize = 3;
Set<Fruit> set = new LinkedHashSet<>();
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
System.out.println(set);
assertEquals(expectedSize, set.size());
}
@Test
public void addAll() {
int expectedSize = 6;
Set<Fruit> set = new LinkedHashSet<>();
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
Set<Fruit> set2 = new LinkedHashSet<>();
set.add(new Fruit("Grape", 4, 1));
set.add(new Fruit("Lemon", 5, 1));
set.add(new Fruit("Mango", 6, 1));
set.addAll(set2);
System.out.println(set);
assertEquals(expectedSize, set.size());
}
@Test
public void remove() {
int expectedSize = 2;
Set<Fruit> set = new LinkedHashSet<>();
Fruit fruit = new Fruit("Longan", 1, 1);
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
set.remove(fruit);
System.out.println(set);
assertEquals(expectedSize, set.size());
}
@Test
public void removeAll() {
int expectedSize = 1;
Set<Fruit> set = new LinkedHashSet<>();
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
Set<Fruit> set2 = new LinkedHashSet<>();
set2.add(new Fruit("Longan", 1, 1));
set2.add(new Fruit("Tomato", 2, 1));
set2.add(new Fruit("Mango", 4, 1));
set.removeAll(set2);
System.out.println(set);
assertEquals(expectedSize, set.size());
}
@Test
public void clear() {
int expectedSize = 0;
Set<Fruit> set = new LinkedHashSet<>();
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
set.clear();
System.out.println(set);
assertEquals(expectedSize, set.size());
}
@Test
public void size() {
int expectedSize = 3;
Set<Fruit> set = new LinkedHashSet<>();
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
System.out.println(set.size());
assertEquals(expectedSize, set.size());
}
@Test
public void isEmpty() {
Set<Fruit> set = new LinkedHashSet<>();
System.out.println(set.isEmpty());
assertTrue(set.isEmpty());
set.add(new Fruit("Longan", 1, 1));
set.add(new Fruit("Tomato", 2, 1));
set.add(new Fruit("Pear", 3, 1));
System.out.println(set.isEmpty());
assertFalse(set.isEmpty());
}
}
心得分享
LinkedHashSet Methods in Java 提供了幾種 LinkedHashSet 常見方法的操作範例,在應用上相當廣泛,熟悉 LinkedHashSet Functions in Java 這些方法的操作,例如: add 、 remove 、 clear 、 size 等。