这篇文章将为大家详细讲解有关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中高并发引发的问题示例”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。