线程

wait() 是Object 类的方法 ,释放锁 。

sleep() 是 Thread 类的方法 ,不释放锁。

死锁产生的4个必要条件
    1、互斥:某种资源一次只允许一个进程访问,即该资源一旦分配给某个进程,其他进程就不能再访问,直到该进程访问结束。
    2、占有且等待:一个进程本身占有资源(一种或多种),同时还有资源未得到满足,正在等待其他进程释放该资源。
    3、不可抢占:别人已经占有了某项资源,你不能因为自己也需要该资源,就去把别人的资源抢过来。
    4、循环等待:存在一个进程链,使得每个进程都占有下一个进程所需的至少一种资源。

  1. 互斥条件:一个资源每次只能被一个进程使用。
  2. 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
  3. 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。

 

public class MyRunnable implements Runnable          { 

     public void run()             { 

         //some code here 

     

 }

正确答案: C  

new Runnable(MyRunnable).start()
new Thread(MyRunnable).run()
new Thread(new MyRunnable()).start()
new MyRunnable().start()

Java中线程实现有两种方式

1、实现Runnable接口,覆盖了run()方法,调用方法, new Thread(new A()).start(),调用线程。(如选项C)

2、继承Thread,并重写run()方法,调用方法,new A().start()   就调用了线程。(如选项D)

 

首先:创建并启动线程的过程为:定义线程—》实例化线程—》启动线程。

一 、定义线程: 1、扩展java.lang.Thread类。 2、实现java.lang.Runnable接口。

二、实例化线程: 1、如果是扩展java.lang.Thread类的线程,则直接new即可。

                 2、如果是实现了java.lang.Runnable接口的类,则用Thread的构造方法:

        Thread(Runnable target) 
        Thread(Runnable target, String name) 
        Thread(ThreadGroup group, Runnable target) 
        Thread(ThreadGroup group, Runnable target, String name) 
        Thread(ThreadGroup group, Runnable target, String name, long stackSize)

所以A、D的实例化线程错误。

三、启动线程: 在线程的Thread对象上调用start()方法,而不是run()或者别的方法。

所以B的启动线程方法错误。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值