• JAVA多线程--Thinking in java


    聊聊并发:http://ifeve.com/java-concurrency-thread-directory/

    阻塞状态:

    sleep  可中断利用 interrupt方法

    wait

    IO  不可中断   I:关闭底层资源  II:new I O

    任务试图在某个对象上调用其同步控制方法,但是对象锁被另一个任务获取  syn不可中断   lock.lockInterruptibly()  可以中断


    Executor.shutdownNow() 发送一个interrupt() 调用给它启动的所有线程 

    如何中断单一任务?

    Executor.submit()启动单一任务 该方法返回一个Futrue<?> 类型的参数

    利用这个参数的cancel(true)即相当于在该线程上调用interrupt() 


    public static void main(String[]args){
            final Test st = new Test();
            new Thread(){
                @Override
                public void run(){
                    st.f1(100);
                }
            }.start();
            System.out.println("main is over");
        }
    }

    刚才写测试用例 突然发现自己对有些概念不是特别明确 比如上面的例子  

    我原以为 main线程输出完那句话 整个程序就结束了 其实并非这样

    只有当把副线程设置为守护线程的时候 才是我想象的那样


    如果在线程上调用interrupt方法停止某个任务 那么在run循环碰巧没有产生任何阻塞的情况下 任务无法中断 

    1可以调用interrupted检查中断状态  while(!Thread.interrupted())


    wait方法

    I带毫秒数,在wait期间对象锁是释放的 可以通过notify notifyall释放 或者时间到期 从wait中恢复 

    II不带参数 wait无限期等待下去

    调用wait notify notifyall 的方法必须在同步控制方法或者同步控制块里


    死锁的四个条件:

    1互斥条件。任务使用的资源至少有一个是不能共享的

    2至少有一个任务它必须持有一个资源且正在等待获取一个当前被别的任务持有的资源。

    3资源不能被任务抢占

    4必须有循环等待

  • 相关阅读:
    面向对象介绍
    常用模块2
    常用模块1
    常用模块3
    模块导入以及常用模块
    模块介绍
    Astra: Apache Cassandra的未来是云原生
    麦格理银行借助DataStax Enterprise (DSE) 驱动数字化转型
    Apache Cassandra使用报告2020
    比较Apache Cassandra的压力测试工具
  • 原文地址:https://www.cnblogs.com/luyu1993/p/6985788.html
Copyright © 2020-2023  润新知