java无序数组_对无序数组的并发搜索的java实现

对无序数组的并发搜索的实现可以充分的用到多cpu的优势

一种简单的策略是将原始数组按照期望的线程数进行分割,如果我们计划使用两个线程进行搜索,就可以把一个数组分成两个,每个线程各自独立的搜索,当其中有一个线程找到数据后,立即返回结果的index即可。

首先index需要采用atomicinteger来进行修饰,默认初始化的值为-1,意义为当前未找到,由于内部采用CAS机制,线程在遍历比较是否相等之前,会通过atomicinteger中的get方法拿到当前的值,如果大于等于0,那么说明别的线程已经找到了结果,直接返回get值就可以。如果比较的过程中发现相等了,那么调用atomicinteger中的compareAndSet(-1,i),如果方法返回成功,则说明当前的线程是第一个发现结果的,那么返回当前index即可,如果失败,则说明别的线程先获得了结果,直接返回atomicinteger中的get方法获取的值即可。

整个过程采用future实现,拿到了Future后,不断地轮询结果,如果大于0即返回结果。

具体实现:

packageparallel;importjava.util.ArrayList;importjava.util.List;importjava.util.concurrent.Callable;importjava.util.concurrent.ExecutionException;importjava.util.concurrent.ExecutorService;importjava.util.concurrent.Executors;importjava.util.concurrent.Future;importjava.util.concurrent.atomic.AtomicInteger;public class SeatchTask implements Callable{static int[] arr = {2,34,5,6};static ExecutorService pool =Executors.newCachedThreadPool();static final int Thread_Num = 2;static AtomicInteger result = new AtomicInteger(-1);intbegin,end,searchValue;public static int search(int searchValue, int beginPos, intendPos){int i = 0;for(i = beginPos; i < endPos;i ++){if(result.get() > 0){returnresult.get();

}if(arr[i] ==searchValue){if(!result.compareAndSet(-1, i)){returnresult.get();

}returni;

}

}return -1;

}

@Overridepublic Integer call() throwsException {int re =search(searchValue, begin, end);returnre;

}public SeatchTask(int searchValue, int begin, intend){this.searchValue =searchValue;this.begin =begin;this.end =end;

}public static int pSearch(int searchValue) throwsInterruptedException, ExecutionException{int subArrSize = arr.length/Thread_Num + 1;

List> re = new ArrayList>();for(int i = 0;i < arr.length;i +=subArrSize){int end = i +subArrSize;if(end <= arr.length) end =arr.length;

re.add(pool.submit(newSeatchTask(searchValue, i, end)));

}for(Futurefu : re){if(fu.get() >= 0){returnfu.get();

}

}return -1;

}public static void main(String[] args) throwsInterruptedException, ExecutionException {int index = pSearch(34);

System.out.println(index);

}

}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值