API学习java.lang.Object.wait

2024-08-22 07:58
文章标签 java 学习 object api lang wait

本文主要是介绍API学习java.lang.Object.wait,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

package com.wonders.week01.object;/*** JDK1.7* wait()* (1)java.lang.Object* (2)权限访问修饰符是public* (3)无返回值* (4)是final修饰的方法,不可以被重写* (5)如果当前线程不是对象监听器上的所有者,则会抛出 异常IllegalMonitorStateException * (6)如果当前线程之前或者在当前线程正在等待通知的时候被任何线程中断,当异常InterruptedException被抛出的时候,* 当前线程的中断状态会被清除。* (7)直到另一个线程调用notify或者notifyAll方法后这个线程才可以不用继续等待。换句话就是,该方法的行为与执行调用wait(0)完全相同。* (8)当前的线程必须拥有对象的监听器。线程放弃了当前对象的监听器的所有权,并且在等待另一个线程来唤醒在对象监听器上正在等待的线程,通过调用* notify或者notifAll方法来唤醒线程。直到线程获得对象监听器的所有权并且可以恢复执行之前,线程会一直处于等待状态。* (9)中断线程和假的唤醒线程是有可能的,这个方法应该总会被用于循环之中:* synchronized (obj) {*       while (<condition does not hold>)*            obj.wait();*        ... // Perform action appropriate to condition*    }* 这个方法只能被当前对象上的线程所有者调用,* @author liyongyong**/
public class WaitTest {/*** wait(long timeout)* (1)java.lang.Object* (2)权限访问修饰符是public* (3)无返回值* (4)是final修饰的方法,不可以被重写* (5)导致当前线程等待,直到另一个线程调用该对象的notify()方法或notifyAll()方法* (6)当前线程必须有自己的对象监听器。* (7)该方法导致当前线程(call it T)将自己放置在该对象的等待设置中,然后放弃所有关于该对象的同步声明,根据线程的时序安排,线程T是不可以使用的,* 并且会一直处于睡眠状态,直到下面四种情况发生时:* (a)这个对象的其他线程调用了notify方法,恰巧线程T被选择为即将唤醒的线程。* (b)这个对象的其他线程调用了notify方法* (c)一些其它的线程中断了线程T* (d)或多或少已经有一些时间过去了,然而,如果时间超时,那么真实的时间将不会被考虑直到该线程被唤醒。* (8)然后将线程T从该对象的等待设置中删除,并为线程调度重新启用。然后接着和其他线程用普通的方式争取同步对象的权力。* 所有关于对象的同步声明都会被存储到之前的状态中,一直到调用wait方法的时候。通过调用wait方法线程T就可以返回了。* 因此,关于从wait方法返回时,对象和线程T的同步状态与调用wait方法时完全一样。* (9)除了notify,中断和超时可以唤醒线程外,线程还可以被虚假唤醒。实际中虚假唤醒线程是很少出现的。应用程序必须对其进行测试,以测试导致线程被唤醒的条件,* 并在条件不满足的情况下继续等待。换句话说,wait应该总出现在循环中,像下面这个:* synchronized (obj) {*    while (<condition does not hold>)*        obj.wait(timeout);*    ... // Perform action appropriate to condition*}*(10)如果当前线程在等待时被任何线程打断,则会抛出异常InterruptedException。这个异常直到对象的锁的状态恢复的时候才会抛出。*(11)注意wait方法,当它将当前线程放到该对象的等待设置中,仅仅只有该对象没有被锁住;当线程等待的时候,当前线程可能同步的任何其他对象仍然被锁定.*(12)该方法只能由一个线程调用,该线程是该对象监视器的所有者. *(13)参数timeout:在毫秒内等待的最长时间*(14)抛出的异常*(a)如果参数的值是一个负数就会抛出异常IllegalArgumentException*(b)如果当前线程不是对象的监听器则会抛出异常IllegalMonitorStateException*(c)如果任何线程在当前线程等待通知之前中断了当前线程。当抛出这个异常时,当前线程的中断状态被清除,会抛出异常InterruptedException 。*//*** wait(long timeout,int nanos)* (1)java.lang.Object* (2)权限访问修饰符是public* (3)无返回值* (4)是final修饰的方法,不可以被重写* (5)方法的参数* (a)timeout:在毫秒内等待的最长时间* (b)nanos:额外的时间,在纳秒范围0 - 999999* (6)抛出的异常* (a)如果参数的值是一个负数就会抛出异常IllegalArgumentException* (b)如果当前线程不是对象的监听器则会抛出异常IllegalMonitorStateException* (c)如果任何线程在当前线程等待通知之前中断了当前线程。当抛出这个异常时,当前线程的中断状态被清除,会抛出异常InterruptedException 。* (7)导致当前线程等待,直到另一个线程调用该对象的notify()方法或notifyAll()方法,或者其他线程中断当前线程.* (8)这个方法和带有一个参数的wait方法是很类似的,但是它允许对于放弃等待唤醒的时间长短有更好的控制。真正的时间是以纳秒级别来计算的,计算公式:1000000*timeout+nanos* (9)在所有的其他层面,该方法和wait(long)这个方法做的是相同的事情,其中wait(0,0)和wait(0)是等价的。* (10)当前线程必须要有自己的事件监听对象。线程将释放该监视器的所有权,并等待直到发生以下两个条件:* (a)另一个线程通知等待这个对象监视器上的线程,通过调用notify方法或notifyAll方法来唤醒它们。* (b)超时时间(以超时毫秒为单位)加上nanos nanoseconds参数,已经过去了.* (11)然后线程等待,直到它重新获得监视器的所有权并恢复执行* (12)中断和虚假唤醒线程是可能的,而且这个方法应该总是在一个循环中使用:* synchronized (obj) {*    while (<condition does not hold>)*        obj.wait(timeout, nanos);*    ... // Perform action appropriate to condition*	}*(13)该方法只能由一个线程调用,该线程是该对象监视器的所有者*/
}

在这里插入图片描述

这篇关于API学习java.lang.Object.wait的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1095693

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06