mirror of
				https://gitee.com/dromara/hutool.git
				synced 2025-10-25 18:29:19 +08:00 
			
		
		
		
	!1008 CollUtil新增anyMatch和allMatch方法
Merge pull request !1008 from gwml/v5-master
This commit is contained in:
		| @@ -667,6 +667,36 @@ public class CollUtil { | ||||
| 		return currentAlaDatas; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 是否至少有一个符合判断条件 | ||||
| 	 * | ||||
| 	 * @param <T> 集合元素类型 | ||||
| 	 * @param collection 集合 | ||||
| 	 * @param predicate 自定义判断函数 | ||||
| 	 * @return 是否有一个值匹配 布尔值 | ||||
| 	 */ | ||||
| 	public static <T>boolean anyMatch(Collection<T> collection,Predicate<T> predicate){ | ||||
| 		if(isEmpty(collection)){ | ||||
| 			return Boolean.FALSE; | ||||
| 		} | ||||
| 		return collection.stream().anyMatch(predicate); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 是否全部匹配判断条件 | ||||
| 	 * | ||||
| 	 * @param <T> 集合元素类型 | ||||
| 	 * @param collection 集合 | ||||
| 	 * @param predicate  自定义判断函数 | ||||
| 	 * @return 是否全部匹配 布尔值 | ||||
| 	 */ | ||||
| 	public static <T>boolean allMatch(Collection<T> collection,Predicate<T> predicate){ | ||||
| 		if(isEmpty(collection)){ | ||||
| 			return Boolean.FALSE; | ||||
| 		} | ||||
| 		return collection.stream().allMatch(predicate); | ||||
| 	} | ||||
|  | ||||
| 	// ----------------------------------------------------------------------------------------------- new HashSet | ||||
|  | ||||
| 	/** | ||||
|   | ||||
| @@ -1057,4 +1057,13 @@ public class CollUtilTest { | ||||
| 		final Object first = CollUtil.getFirst(nullList); | ||||
| 		Assert.assertNull(first); | ||||
| 	} | ||||
|  | ||||
| 	@Test | ||||
| 	public void testMatch() { | ||||
| 		List<Integer> list = Arrays.asList(1, 2, 3, 4, 5, 6); | ||||
| 		Assert.assertTrue(CollUtil.anyMatch(list, i -> i == 1)); | ||||
| 		Assert.assertFalse(CollUtil.anyMatch(list, i -> i > 6)); | ||||
| 		Assert.assertFalse(CollUtil.allMatch(list, i -> i == 1)); | ||||
| 		Assert.assertTrue(CollUtil.allMatch(list, i -> i <= 6)); | ||||
| 	} | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Looly
					Looly