阿里巴巴笔试测评的两道题

image.png

以下是菜鸟(本人)写的代码,请大牛勿笑,烦劳指点一下:

package me.qianlv;

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;

public class NumberPrinter {
    private volatile int start;
    private volatile int end;
    private ReentrantLock lock = new ReentrantLock();
    private Condition condition = lock.newCondition();

    public NumberPrinter(int start, int end) {
        this.start = start;
        this.end = end;
    }

    public boolean isPrime(int num) {
        if (num == 1) return false;
        for (int i = 2; i <= Math.sqrt(num); i++) {
            if (num % i == 0)
                return false;
        }
        return true;
    }

    public static void main(String[] args) {
        NumberPrinter numberPrinter = new NumberPrinter(1, 100);
        System.out.println(numberPrinter.isPrime(99));
    }

    public void printPrime() {
        try {
            lock.lock();
            while (start < end) {
                System.out.println("质数:::" + start);
                while (!isPrime(start) && start < end) {
                    System.out.println("质数--等待" + start);
                    condition.await();
                }
                System.out.println(Thread.currentThread().getName() + " 质数: " + start);
                start++;
                condition.signalAll();
            }
        } catch (InterruptedException e) {
            e.printStackTrace();
        } finally {
            lock.unlock();
        }
    }

    public void printOther() {
        try {
            lock.lock();
            while (start < end) {
                System.out.println("其他:::" + start);
                while (isPrime(start) && start < end) {
                    System.out.println("其他--等待" + start);
                    condition.await();
                }
                System.out.println(Thread.currentThread().getName() + " 非质数: " + start);
                start++;
                condition.signalAll();
            }
        } catch (InterruptedException e) {
            e.printStackTrace();
        } finally {
            lock.unlock();
        }
    }
}

class RunableA implements Runnable {
    private NumberPrinter numberPrinter;

    public RunableA(NumberPrinter numberPrinter) {
        this.numberPrinter = numberPrinter;
    }

    @Override
    public void run() {
        numberPrinter.printPrime();
    }
}

class RunnableB implements Runnable {
    private NumberPrinter numberPrinter;

    public RunnableB(NumberPrinter numberPrinter) {
        this.numberPrinter = numberPrinter;
    }

    @Override
    public void run() {
        numberPrinter.printOther();
    }
}

class Test {
    public static void main(String[] args) {
        NumberPrinter numberPrinter = new NumberPrinter(1, 259);

        Thread threadA = new Thread(new RunableA(numberPrinter), "A");
        Thread threadB = new Thread(new RunnableB(numberPrinter), "B");
        threadA.start();
        threadB.start();
    }
}

class Str2NumUtil {
    public static int str2num(String str) {
        if (!str.matches("^-?\\d+$")) {
            throw new IllegalArgumentException("字符串不能解析成数字");
        }
        return Integer.parseInt(str);
    }

    public static void main(String[] args) {
        System.out.println(str2num("-123.01"));
    }
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,778评论 25 709
  • 自西方文艺复兴以来,中国在自然科学方面落后西方很多,软件领域也不例外。当然现在中国的许多程序员们对此可能有许多不同...
    一切成迷阅读 2,102评论 2 31
  • 自西方文艺复兴以来,中国在自然科学方面落后西方很多,软件领域也不例外。当然现在中国的许多程序员们对此可能有许多不同...
    DanD丶榆木稚年阅读 613评论 0 2
  • 为了把死板无趣的玉米饼做出胖嘟嘟的外观,为了把单一味道的玉米饼做出不一样的味道,我早上是下大功夫了。白糯玉米粉...
    伊人若雨阅读 244评论 0 2
  • 在未来世界——29世纪的科技非常发达。 在29世纪,每个人都会有一把光剑来护身。在22世纪的车,现在全变成飞的,能...
    李Joey阅读 257评论 0 1