0 0

java 多线程,如何实现,如果没有获取到锁就跳过(或做其他的)而不是等待0

java 多线程,如何实现,如果没有获取到锁就跳过(或做其他的)而不是等待,我的需求是,如果我没有获取到锁我就做其他事情,而不是一直等到锁释放。如何实现?谢谢
2012年8月28日 22:28

3个答案 按时间排序 按投票排序

0 0

可以这样,
定义一个标识,来判断是否获取到了.
在之前需要等待的代码位置,将它用线程去执行等待,线程中,如果得到了就修改一个标识.
取代等待的代码为:判断标识是否改变了.
可否?

2012年8月29日 18:16
0 0

问题没有描述清楚啊,如果是没有获得锁,要么是干脆放弃,要么是做其他的事情,在做其他的事情的时候,还要去尝试获取锁。第一种的话,用ReentranLock.tryLock()就可以了。第二种的话,需要做一个循环等待,在循环中,处理其他的事情,或者另起一个线程,定时去请求锁

2012年8月28日 23:02
0 0

ReentrantLock 

2012年8月28日 22:31

相关推荐

    Java中的锁分类与使用.docx

    Java中的锁机制是多线程编程中不可或缺的一部分,它们用于管理对共享资源的并发访问,确保数据的一致性和完整性。本文将深入探讨Java中的几种主要锁类型及其使用。 1. **乐观锁**与**悲观锁** - **乐观锁**假设...

    多线程(11)ReentrantLock公平锁与非公平锁(修改)1

    非公平锁并不保证线程的获取顺序,它允许线程在尝试获取锁时跳过队列的末尾,直接进行尝试。在`main`方法中,后两个线程使用的是非公平锁(`unfairLock`)。这意味着即使在其他线程已经在等待的情况下,新线程也...

    用JAVA实现缓冲多线程无阻塞读取远程文件.pdf

    在Java中实现缓冲多线程无阻塞读取远程文件的知识点主要包括Java I/O操作、多线程编程、网络编程以及缓冲机制的使用。以下是根据所提供的文件内容整理的知识点: 1. Java I/O操作基础 - `java.io.InputStream`: 一...

    Java线程公平锁和非公平锁的差异讲解

    Java线程公平锁和非公平锁是Java并发...总的来说,Java线程公平锁和非公平锁是并发控制的重要机制,它们的设计和选择直接影响到多线程程序的性能和并发行为。理解并合理运用这两种锁,有助于编写高效、稳定的并发程序。

    HttpURLConnection实现单线程下载,多线程下载,多线程续点下载

    本教程将详细讲解如何使用HttpURLConnection实现单线程、多线程下载以及多线程续点下载。 **一、单线程下载** 单线程下载是最基础的下载方式,它通过一个连接获取服务器资源并写入本地文件。以下是一个简单的单...

    ReentrantLock源码的使用问题详解.docx

    而在NonfairSync中,线程获取锁时会尝试直接通过CAS操作获取,即使这意味着可能会跳过队列中的其他线程。 在AQS中,state字段是关键,它表示锁的当前状态。当state为0时,表示锁未被任何线程持有。在...

    基于JDK源码解析Java领域中的并发锁,我们需要特别关注哪些内容?

    在尝试获取锁时,公平锁遵循FIFO原则,而非公平锁则可能跳过等待队列中的线程。 3. **ReentrantReadWriteLock(读写锁)**: - **设计思想**:允许多个读取者同时访问,但只有一个写入者,提高并发性能。 - **...

    corejava_面试题

    Java基础知识讲解与面试题分析: 1. Java源文件中是否可以...Java中可以通过继承Thread类、实现Runnable接口以及使用Callable接口和FutureTask类来实现多线程。同步可以通过synchronized关键字或者显式锁Lock类实现。

    偏向锁理论太抽象,实战了解下偏向锁如何发生以及如何升级【实战篇】.doc

    在Java虚拟机(JVM)中,当一个线程访问同步块并获取锁时,如果发现对象头的Mark Word标记为偏向锁状态(101),且锁对象未被其他线程持有,JVM就会将该线程的线程ID记录在Mark Word中,并将锁状态保持为偏向锁。...

    Android-Android多线程下载项目

    通过分析这个"Android-Android多线程下载项目",我们可以学习到如何在Android环境中高效地实现多线程下载,掌握线程池的使用,以及断点续传的关键技术。这对于任何希望提升Android应用性能和用户体验的开发者来说,...

    zookeeper 分布式锁

    ZooKeeper的分布式锁既可以实现公平锁(按照创建节点的顺序获取锁),也可以实现非公平锁(允许某些客户端跳过队列提前获取锁)。这取决于创建和检查节点的顺序策略。 总的来说,ZooKeeper提供了高效且可靠的分布式...

    Java线程安全问题小结_动力节点Java学院整理

    volatile变量的修改会立即同步到主内存,且其他线程在读取时会直接从主内存读取,跳过工作内存。 2. 有序性:JVM允许对指令进行重排序,以提高执行效率,但这种重排序可能会导致线程看到的数据不是预期的顺序。例如...

    多线程断点续传并在通知栏显示进度

    在单线程下载中,数据流通常会被限制在一个线程中,而多线程则可以同时从服务器获取多个数据块,利用网络带宽的并行性,从而提高下载效率。在Android中,我们可以使用`AsyncTask`或`ExecutorService`来创建并管理...

    Redis 分布式锁使用

    默认情况下,`lock()`方法是非公平锁,这意味着线程可能会跳过等待队列提前获取锁。若需要公平锁,可以使用`tryLock()`方法,并传入`true`作为公平参数: ```java if (lock.tryLock(0, Long.MAX_VALUE, TimeUnit....

    Java基础整理

    - **死锁**:两个或多个线程互相等待对方持有的锁而无法继续执行的情况。 - **线程间通信**:线程之间通过共享资源或消息传递等方式进行通信。常用的方法包括`wait()`、`notify()`等。 - **JDK1.5新特性**:引入了`...

    详细的java基础总结

    特殊流程控制语句包括`break`和`continue`,用于提前终止循环或跳过当前循环的剩余部分。 - **方法** 方法是Java中封装一系列操作的单位。方法可以接受参数并返回值。方法的定义格式为: ``` 返回类型 方法名...

    java牛人总结

    然而,Java中有一种类似`goto`的替代品——标签化的`break`和`continue`语句,它们可以用于从循环中提前退出或跳过某些迭代,尽管这并不等同于C或C++中的`goto`。 #### 3\. `&`与`&&`的区别 在Java中,`&`和`&&`都...

    Java 中synchronize函数的实例详解

    在Java编程语言中,`synchronized`关键字用于实现线程同步,以确保在多线程环境下对共享资源的访问是安全的。当一个方法被声明为`synchronized`时,同一时刻只能有一个线程执行该方法,其他试图访问的线程必须等待...

    将Oracle数据库表用作多线程工作队列

    跳过锁定允许查询忽略被锁定的行,避免了因等待锁导致的阻塞,从而提高了并发性能。在工作队列场景中,这个特性可以确保多个线程并行处理任务,而不会相互干扰。 在设计这样的工作队列时,通常会采用以下步骤: 1. ...

Global site tag (gtag.js) - Google Analytics