这篇文章将为大家详细讲解有关java中高并发引发的问题示例,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
示例模拟10000次请求,每次并发数为100,每次请求,计数器加1,最后输出计数器值。
上代码:
package concurrent; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Semaphore; /** * @Description: 并发测试 */ public class ConcurrentSample { //并发线程数量 private static int users = 100; //访问次数 private static int count = 10000; //访问总量 private static int number = 0; public static void main(String[] args) { //定义线程池 ExecutorService executorService = Executors.newCachedThreadPool(); //并发量 Semaphore semaphore = new Semaphore(users); for (int i = 0; i < count; i++) { executorService.execute(() -> { try { semaphore.acquire(); add(); semaphore.release(); } catch (Exception e) { e.printStackTrace(); } }); } try { Thread.sleep(3000); } catch (Exception e) { e.printStackTrace(); } executorService.shutdown(); System.out.println(number); } public static void add() { number++; } }
计数器:9997
计数器:10000
计数器:9997
每次输出结果不一致,这都是并发导致的
关于“java中高并发引发的问题示例”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
原创文章,作者:306829225,如若转载,请注明出处:https://blog.ytso.com/237745.html