`
zysnba
  • 浏览: 189118 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

CollectionUtil

 
阅读更多
package com.huwei.modules.base.util;

import java.util.Arrays;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Objects;
import java.util.Set;
import java.util.concurrent.ConcurrentLinkedQueue;

public class CollectionUtil {

/**
* int数组转字符串数组
* @param as
* @return
*/
static public String[] switchArray(Integer[] as) {
if(as == null) {
return new String[] {};
}
String[] result = new String[as.length];
for(int i = 0 ,len = as.length ;i < len ;++i) {
result[i] = String.valueOf(as[i]);
}
return result;
}

/**
* 数组中包含指定元素
* @param ele 元素
* @param arrays 数组
* @return
*/
static public boolean contains(String[] arrays ,String ele) {
if(Objects.isNull(arrays) || arrays.length == 0) {
return false;
}
for(int i = 0 ,len = arrays.length ;i < len ;++i) {
if((ele == null && arrays[i] == null) || (ele != null && ele.equals(arrays[i]))) {
return true;
}
}
return false;
}

/**
* 查找集合的交集
* @param a
* @param b
* @return
*/
static public int[] intersection(int[] a ,int[] b) {
if(Objects.nonNull(a) && Objects.nonNull(b)) {
return a.length > b.length ? intersection0(b, a)
: intersection0(a, b);
}

return new int[] {};
}

static private int[] intersection0(int[] minArray ,int[] maxArray) {
int[] temp = new int[minArray.length];
int count = 0;

for(int i = 0 ,minLen = minArray.length ;i < minLen ;++i) {
int currentVal = minArray[i];
if(!contains(currentVal, temp ,0 ,count)) {
if(contains(currentVal ,maxArray ,0 ,maxArray.length)) {
temp[count++] = currentVal;
}
}
}

int[] result0 = new int[count];
System.arraycopy(temp, 0, result0, 0, count);

return result0;
}

/**
* 使用二分算法查询集合的交集
* @param a
* @param b
* @return
*/
static public int[] intersectionByBinarySearch(int[] a ,int[] b) {
if(Objects.nonNull(a) && Objects.nonNull(b)) {
return a.length > b.length ? intersectionByBinarySearch0(b, a)
: intersectionByBinarySearch0(a, b);
}

return new int[] {};
}

static private int[] intersectionByBinarySearch0(int[] minLengthArray ,int[] maxLengthArray) {
Set<Integer> tempResult = new HashSet<Integer>();

Arrays.sort(minLengthArray);
Arrays.sort(maxLengthArray);

for(int i = 0 ,len = minLengthArray.length ;i < len ;++i) {
int currentVale = minLengthArray[i];

if(Arrays.binarySearch(maxLengthArray, currentVale) >= 0) {
tempResult.add(Integer.valueOf(currentVale));
}
}

return setToArray(tempResult);
}

/**
* 多线程的方式,应该有调用者实现多线程
* @param a
* @param b
* @return
*/
static public int[] intersectionByMultithread(int[] a ,int[] b) {
if(Objects.nonNull(a) && Objects.nonNull(b)) {
return a.length > b.length ? intersectionByMultithread0(b, a)
: intersectionByMultithread0(a, b);
}

return new int[] {};
}

static public int[] intersectionByMultithread0(int[] minLengthArray ,int[] maxLengthArray) {
int threadNumber = Runtime.getRuntime().availableProcessors();
int maxLength = maxLengthArray.length;
int sliceArrayBaseLength = maxLength / threadNumber;

if(sliceArrayBaseLength <= 1) {return intersectionByBinarySearch0(minLengthArray, maxLengthArray);}

ConcurrentLinkedQueue<Object> tempResult = new ConcurrentLinkedQueue<>();

for(int i = 0 ;i < threadNumber ;++i) {
int sliceArrayStartIndex = sliceArrayBaseLength * i;
int sliceArrayEndIndex =
sliceArrayBaseLength + sliceArrayBaseLength + sliceArrayStartIndex > maxLength ?
maxLength : sliceArrayBaseLength + sliceArrayStartIndex;

int currentSliceArrayLength = sliceArrayEndIndex - sliceArrayStartIndex;

int[] sliceArray = new int[currentSliceArrayLength];
System.arraycopy(maxLengthArray, sliceArrayStartIndex, sliceArray, 0, currentSliceArrayLength);

new Thread(()->{
tempResult.add(intersectionByBinarySearch(minLengthArray, sliceArray));
}).start();
}

while(tempResult.size() != threadNumber) {
try {
Thread.sleep(1);
} catch (InterruptedException e) {
}
}

int[] result = new int[0];
while(!tempResult.isEmpty()) {
result = combineAndRemoveRepeating(result, (int[])tempResult.poll());
}

return result;
}

/**
* 查询array中是否包含val值
* @param val
* @param array
* @param offset
* @param len
* @return
*/
static public boolean contains(int val ,int[] array ,int offset,int len) {
checkNull(array);
checkIndex(offset, len, array.length);

int i = offset;
for(;i < len ;++i) {
if(val == array[i]) {
return true;
}
}

return false;
}

static private void checkNull(Object ...obj) {
if(Objects.isNull(obj)) {
throw new NullPointerException("array is null");
}

for(int i = 0 ,len = obj.length ;i < len ;++i) {
if(Objects.isNull(obj[i])) {
throw new NullPointerException("array is null");
}
}
}

static private void checkIndex(int offset ,int srcLen ,int arrayLen) {
if(offset < 0 || srcLen < offset || srcLen > arrayLen) {
throw new RuntimeException("index is error ,offset = " + offset + " ;len = " + srcLen);
}
}

/**
*  将数组a和数组b组合为新的数组
* @param a
* @param b
* @return
*/
public static int[] combine(int[] a, int[] b) {
checkNull(a,b);

int[] result = new int[a.length + b.length];

System.arraycopy(a, 0, result, 0, a.length);
System.arraycopy(b, 0, result, a.length, b.length);

return result;
}

/**
* 查询数组a 和 数组b的非交集
* @param a
* @param b
* @return
*/
static public int[] nonredundant(int[] a, int[] b) {
checkNull(a,b);

return a.length > b.length ? nonredundant0(b, a) : nonredundant0(a, b);
}

static private int[] nonredundant0(int[] minLengthArray, int[] maxLengthArray) {
Set<Integer> tempResult = new HashSet<>();

Arrays.sort(minLengthArray);
Arrays.sort(maxLengthArray);

for(int i = 0 ,len = maxLengthArray.length ;i < len ;++i) {
if(Arrays.binarySearch(minLengthArray, maxLengthArray[i]) < 0) {
tempResult.add(maxLengthArray[i]);
}
}

for(int i = 0 ,len = minLengthArray.length ;i < len ;++i) {
if(Arrays.binarySearch(maxLengthArray, minLengthArray[i]) < 0) {
tempResult.add(minLengthArray[i]);
}
}

return setToArray(tempResult);
}

/**
* 合并数组并去掉重复的数据
* @param a
* @param b
* @return
*/
static public int[] combineAndRemoveRepeating(int[] a ,int[] b) {
checkNull(a,b);

Set<Integer> resultSet = new HashSet<>();

copyToSet(a, resultSet);
copyToSet(b, resultSet);

return setToArray(resultSet);
}

static private void copyToSet(int[] src ,Set<Integer> dest) {
for(int i = 0 ,len = src.length ;i < len ;++i) {
dest.add(Integer.valueOf(src[i]));
}
}

static private int[] setToArray(Set<Integer> src) {

if(Objects.nonNull(src) && !src.isEmpty()) {
int[] result = new int[src.size()];
int writeIndex = 0;

Iterator<Integer> iter = src.iterator();
while(iter.hasNext()) {
result[writeIndex++] = iter.next().intValue();
}

return result;
}

return new int[] {};
}
// static public void main(String[] args) {
// int[] a = new int[] {1,2,3};
// int[] b = new int[] {2,3,4};
// System.out.println(Arrays.toString(intersection(a, b)));
// }
}
分享到:
评论

相关推荐

    CollectionUtil.java

    Java开发中中经常使用的Java工具类分享,工作中用得上,直接拿来使用,不用重复造轮子。

    自己编写的基于jdk1.5的开源工具包

    (OperationUtil.java)Collection工具包类(CollectionUtil.java)等等,如果下载者觉得使用方面的话,在下十分感谢,申明:代码没有经过十分严格测试,纯属自己爱好和方便编写的一些代码积累。

    给程序员用的基于Java语言的工具集canoe-util-master.zip

    2. CollectionUtil:集合相关的辅助工具,包括集合的创建、遍历、比较以及集合元素的转换等。 3. StringUtil:提供字符串的高级操作,例如检查空值、替换、分割、连接等,还能进行正则表达式匹配。 4. LogUtil:提供...

    mybatis-plus-join是mybatis plus的一个多表插件

    mybatis-plus-join是mybatis plus的一个多表插件,只要会用mp就会用这个插件,仅仅依赖了lombok,而且是扩展mp的构造器并非更改原本的构造器,不会对原有项目产生一点点影响 mybatis-plus的多表插件完全按照mybats ...

    Utility基础类大全_CN.rar

    例如,`CollectionUtil.ContainsAny(IEnumerable&lt;T&gt; source, IEnumerable&lt;T&gt; items)`可以检查源集合是否包含目标集合中的任何元素。 7. **异常处理**: ExceptionUtil类可能提供了一些处理异常的辅助方法,如记录...

    常用的工具类文件

    3. **CollectionUtil**: 针对Java集合框架的操作,CollectionUtil可能包含对List、Set、Map等进行操作的方法,如集合的合并、去重、排序、过滤等。例如,`isEmpty()`检查集合是否为空,`merge()`合并两个集合,`...

    JAVA工具模块TBOX

    3. **集合工具类(CollectionUtil)**:集合处理是Java开发中的重要环节,CollectionUtil提供了一系列针对List、Set、Map等集合的操作,如集合的合并、分割、去重、排序等,使得集合操作更加便捷。 4. **IO流工具类...

    Utility基础类大全.zip_Q98_c#工具类_c#通用类_happenedm1i_untlity

    3. **集合操作**:集合操作工具类,如`CollectionUtil`,可以提供对数组、列表或其他集合类型的扩展方法,如查找、排序、去重、合并等。 4. **文件和目录操作**:`FileUtil`和`DirectoryUtil`可能封装了文件系统的...

    agile-framework-common-util-master_java_

    `common-util`模块是Agile Framework Common Util的核心部分,它包含了各种通用的工具方法,除了`ObjectUtil`外,可能还包括`ArrayUtil`、`CollectionUtil`、`MapUtil`等,分别提供了对数组、集合和映射的操作支持。...

    java常用工具类iceroot开源类库.zip

    3. **集合操作**:CollectionUtil类可能包含对List、Set、Map等各种集合的扩展操作,如快速合并、过滤、转换等,使得集合操作更加灵活。 4. **文件操作**:FileUtil类可能提供了读写文件、复制文件、检查文件或目录...

    C# 实用类集 DotNet.Utilities 整理完整版,集合的比较全

    比如,可能存在一个`CollectionUtil`类,包含`Sort`方法对自定义对象进行排序,`Merge`方法合并两个列表,并且`RemoveDuplicates`方法删除集合中的重复元素。 此外,文件和IO操作也是常见功能之一。`DotNet....

    一些Java的自写工具包

    3. `CollectionUtil.java`:集合操作的工具类,如清空、合并、过滤、排序等集合对象。 4. `NumberUtil.java`:数值计算和转换的工具,包括数学运算、格式化输出、数字安全处理等。 5. `FileUtil.java`:文件和IO流...

    java常用工具类和接口返回对象.zip

    3. **CollectionUtil**:集合操作相关的工具类,可能包括了对List、Set、Map等数据结构的通用操作,如查找、添加、删除元素,转换集合类型,集合合并等。这些方法可以减少手动处理集合时的代码量。 4. **IOUtil**:...

    C#常用工具类

    这可能在`CollectionUtil`类中实现。 4. **文件和流操作**:`System.IO`命名空间虽然提供了基本的文件和流操作,但工具类可能提供了更友好的接口,如读写文件、复制移动文件、压缩解压缩文件、处理目录等。 5. **...

    java常用工具类封装util.rar

    3. **集合工具类(CollectionUtil)**:此类通常包含对List、Set、Map等各种集合的操作,如添加元素、删除元素、合并集合、检查是否为空等。例如`isEmpty()`用于判断集合是否为空,`merge()`用于合并两个集合。 4. **...

    Java工具类

    例如,`CollectionUtil`可能包含`isEmpty(Collection&lt;?&gt; coll)`来检查集合是否为空,或`merge(List&lt;?&gt;... lists)`来合并多个列表。 对于处理中文和拼音,`PinyinUtil`工具类可以帮助转换汉字到拼音,这对于搜索、...

    27个java工具类

    10. **CollectionUtil**:集合操作工具类,用于处理Java的集合框架,如List、Set和Map。它可以实现集合的合并、分割、排序、去重等操作。 11. **JsonUtil**:JSON(JavaScript Object Notation)序列化和反序列化的...

    常用工具类

    3. **集合工具类**:如`CollectionUtil`,提供对集合的增删查改、遍历、合并、复制等功能。 4. **文件操作工具类**:如`FileUtil`,包括读写文件、创建删除文件夹、文件转换等操作。 5. **网络请求工具类**:如`...

Global site tag (gtag.js) - Google Analytics