ARTS-第一周,习惯养成

235 阅读2分钟

Algorithm

整数反转

给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。 示例 1:

输入: 123 输出: 321 示例 2:

输入: -123 输出: -321 示例 3:

输入: 120 输出: 21

public int reverse(int x) {
        if (x > Integer.MAX_VALUE || x < Integer.MIN_VALUE){
            return 0;
        }

        if (x == 0 ){
            return 0;
        }

        boolean flag = x >= 0;
        Long xL = new Long(x);
        String xDataStr = new String(Math.abs(xL.longValue())+"");
        char[] xData = xDataStr.toCharArray();
        StringBuilder dataBuilder = new StringBuilder();

        if (!flag){
            dataBuilder.append("-");
        }

        for (int i=0 , total = xDataStr.length() ; i < total ; i++){
            if (dataBuilder.toString().length() == 0 && xData[total - i - 1] == '0'){
                continue;
            }
            dataBuilder.append(xData[total - i - 1]);
        }

        Long result = Long.parseLong(dataBuilder.toString());
        if (result.longValue() > Integer.MAX_VALUE || result.longValue() < Integer.MIN_VALUE){
            return 0;
        }
        return result.intValue();
    }

Review

没有阅读

Tip

ThreadPoolExector的参数

参数名称 说明 其他
核心线程数 线程池核心线程数量,核心线程不会被回收,即使没有任务执行,也会保持空闲状态
最大线程数 池允许最大的线程数,当线程数量达到corePoolSize,且workQueue队列塞满任务了之后,继续创建线程。 "Isn't this fun?"
keepAliveTime 保持时间 超过corePoolSize之后的“临时线程”的存活时间
unit 保持时间 keepAliveTime的单位
workQueue 阻塞队列大小 当前线程数超过corePoolSize时,新的任务会处在等待状态,并存在workQueue中,BlockingQueue是一个先进先出的阻塞式队列实现,底层实现会涉及Java并发的AQS机制
threadFactory 创建线程的工厂类,通常我们会自顶一个threadFactory设置线程的名称,这样我们就可以知道线程是由哪个工厂类创建的,可以快速定位
handler 拒绝策略 1、AbortPolicy:为线程池默认的拒绝策略,该策略直接抛异常处理2、DiscardOldestPolicy:丢弃队列中最老的任务3、CallerRunsPolicy:将任务分配给当前执行execute方法线程来处理4、DiscardOldestPolicy:丢弃队列中最老的任务 自定义拒绝策略,只需要实现RejectedExecutionHandler接口即可

Share

java锁浅析: link.