Java并发编程入门与高并发面试——001

题目:

当前200个用户同时发起请求,共接收5000个请求,每次请求add操作,count++。

代码:

@Slf4j
public class CountExample {

    // 请求总数
    public static int clientTotal = 5000;
    // 同时并发执行的线程数
    public static int threadTotal = 1;

    public static long count = 0;

    public static void main(String[] args) {
        ExecutorService executorService = Executors.newCachedThreadPool();
        final Semaphore semaphore = new Semaphore(threadTotal); // 同时申请200个请求
        for (int i = 0; i < clientTotal; i++) {
            executorService.execute(new Runnable() {

                @Override
                public void run() {
                    try {
                        semaphore.acquire();// 申请一个许可
                        add();
                        semaphore.release(); // 释放一个许可
                    } catch (InterruptedException e) {
                        log.error("exception", e);
                    }
                }
            });
        }
        executorService.shutdown();
        log.info("count:" + count);
    }

    private static void add() {
        count++ ;
    }
}

分析:

在threadTotal = 1或者threadTotal = 200时,牵着每次执行结果都不一样,后者都是为5000。

对于简单的累加操作,5000个线程同一时间只有一个进程执行和200个进程执行时不一样的!

类似我们本地模拟式一个进程,怎么模拟都是对的,一旦上线就会出错,此时我们就要考虑是否是并发问题!

并发模拟:

  • PostMan:Http请求模拟工具
  • Apache Bench(AB):Apache附带的工具,测试网站性能
  • JMeter:Apache组织开发的压力测试工具

其他资料:

  1. 关于信号量Semaphore的acquire与release的说明 
  2. CountDownLatch是什么

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值