`
wkwukong
  • 浏览: 9454 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

一种JAVA线程轮训调度算法(转载)

阅读更多

话不多说,直接上代码(本算法转载自“并发编程网 http://ifeve.com”)。

 

public class CycleAtomicInteger {
private final static long PARK_TIME = 1000L * 1000;

private AtomicInteger counter = new AtomicInteger(0);

private int range;

public CycleAtomicInteger(int range) {
    if (range < 2)
        throw new IllegalArgumentException();
    this.range = range;
}

/**
 * 获取下个原子值
 *
 * @return
 */
public int next() {
    for (;;) {
        int c = counter.get();
        int next = (c + 1) % range;
        if (counter.compareAndSet(c, next)) {
            return c;
        } else {
            LockSupport.parkNanos(PARK_TIME);
        }
    }
}

}



原文链接:(http://ifeve.com/13840/)
分享到:
评论

相关推荐

    基于Java的移动臂磁盘调度算法(动态显示)

    移动臂磁盘调度算法是一种用于决定磁头如何在磁盘上移动以满足不同扇区读写请求的方法。本项目基于Java技术,实现了多种经典的移动臂调度算法,并且通过图形用户界面(GUI)和线程技术动态展示其工作过程,提供了...

    调度算法 java源代码

    在项目"diaodu"中,可能包含实现了上述一种或多种调度算法的Java源代码,通过阅读和分析这些代码,我们可以学习到如何在Java中构建一个高效的调度系统,同时也能对调度算法的原理和实践有更深入的理解。

    电梯调度算法(java实现)

    1. **先来先服务(FCFS, First-Come, First-Served)**:这是一种简单的策略,按照电梯收到请求的顺序进行服务,就像CPU调度中的FCFS一样。虽然公平,但可能造成较长的平均等待时间。 2. **最短旅行时间(STT, ...

    大规模虚拟地形数据多线程异步调度算法.pdf

    总的来说,这篇论文提出了一个基于四叉树和Hilbert曲线的空间数据组织方法,结合IOCP和多线程技术,设计了一种高效的大规模虚拟地形数据调度算法。这种方法对于提升虚拟现实场景中大规模地形的渲染速度和用户体验...

    Java 模拟进程调度算法

    轮转算法是一种时间片驱动的调度策略,其基本思想是将所有就绪进程放入一个队列中,每次分配一个固定的时间片给队首进程执行。当时间片用完后,无论该进程是否完成,都会被强制切换到就绪队列的末尾,由下一个进程...

    Nachos实现id、限制线程数和按优先级调度算法 源码.rar

    然后,优先级调度算法是操作系统中用于决定哪个线程应该获得CPU执行权的一种策略。在Nachos中,`scheduler.cc`和`scheduler.h`很可能是实现这一算法的关键文件。通常,高优先级的线程会被优先调度,以保证对时间敏感...

    调度算法 调度算法 调度算法

    这是一种综合性的调度算法,通过设置多个优先级不同的队列,并为每个队列分配不同的时间片和调度策略,实现了既考虑任务紧急程度又兼顾公平性的效果。 ### 总结 调度算法是操作系统中极其重要的组成部分,它不仅...

    Linux超线程感知的调度算法研究

    Linux超线程感知的调度算法研究是针对Intel的Hyper-Threading Technology进行的一种优化技术,旨在提升处理器在Linux操作系统下的性能。超线程技术是Intel在2002年推出的一种微处理器架构,它通过共享处理器资源,...

    实现FCFS,FJF进程(线程)调度算法_实验报告

    《实现FCFS与FJF进程(线程)调度算法的C语言编程实践》 在计算机操作系统中,进程调度是核心功能之一,它决定了哪些进程能在何时获得CPU资源执行。本实验报告主要探讨了两种经典的调度算法:先来先服务(FCFS)和...

    Java操作系统磁盘调度算法

    6. **电梯调度(又称FIFO for seeks, Elevator Algorithm)**:这是一种结合了SCAN和SSTF特点的算法,它沿着一个方向服务请求,同时遵循SSTF原则。当达到磁盘边界时,就像电梯一样改变方向。 理解这些磁盘调度算法有...

    基于java swing的多线程电梯调度模拟

    Swing是Java提供的一种图形用户界面(GUI)工具包,它允许开发者创建窗口应用。在这个文件中,开发者可能定义了电梯显示、楼层按钮、以及乘客请求输入等组件。同时,它还需要处理用户交互事件,比如当用户点击某个...

    操作系统调度算法

    操作系统调度算法是指操作系统中对进程或线程的调度和管理的一种算法。它的主要目标是提高系统的效率、公平性和响应速度。操作系统调度算法可以分为两类:非抢占式调度算法和抢占式调度算法。非抢占式调度算法是指在...

    磁盘调度算法 操作系统作业 java模拟磁盘调度,图形界面

    这里我们将深入探讨磁盘调度的基本概念、常见算法以及如何使用Java进行模拟。 一、磁盘调度基本概念 磁盘调度是指当多个进程或线程请求磁盘I/O操作时,操作系统根据一定的策略来决定执行哪个请求的顺序。这个过程...

    线程调度的优先级

    线程调度是多任务操作系统中的一个关键概念,它决定了如何在多个并发运行的线程之间分配CPU的时间片。线程调度的优先级是决定哪些线程应该先获得执行权的重要因素,尤其对于Java这样的多线程编程环境。下面将详细...

    磁盘调度算法实验报告(20210919121020).pdf

    磁盘调度算法是操作系统中的一种重要机制,用于管理磁盘I/O操作,提高磁盘访问的效率。本实验报告的主要内容是对磁盘调度算法的实验设计、实现和验证。 一、实验概述 磁盘调度算法实验的主要目的是通过学习EOS实现...

    线程 JAVA java线程 java线程第3版 java线程第2版第3版合集

    电子书相关:包含4个有关JAVA线程的电子书(几乎涵盖全部有关线程的书籍) OReilly.Java.Threads.3rd.Edition....第七章 Java线程调度例子 第八章 和同步相关的高级主题 第九章 多处理器机器上的并行化 第十章 线程组

    优先调度算法和循环轮转调度算法

    在这个基于Java语言的操作系统实验中,我们将深入探讨这两种算法的原理、实现以及它们在窗口界面环境下的应用。 首先,优先级调度算法是一种根据进程优先级决定执行顺序的调度方法。它分为抢占式和非抢占式两种类型...

    java用多线程进行排序算法的比较

    快速排序是一种高效的排序算法,由C.A.R. Hoare在1960年提出。它的基本思想是“分而治之”(Divide and Conquer)。快速排序的主要步骤包括: 1. **选择主元**:在待排序的数组中选取一个元素作为“基准”或“主元...

    操作系统编程进程或作业先来先服务、高优先权、按时间片轮转调度算法

    本实验报告旨在通过编写程序实现进程或作业先来先服务、高优先权、按时间片轮转调度算法,了解 Windows2000/XP 中进程(线程)的调度机制,并学习使用 Windows2000/XP 中进程(线程)调度算法,掌握相应的与调度有关...

    精选_毕业设计_基于JAVA的进程调度算法_完整源码

    1. **Java编程语言**:Java是一种广泛使用的面向对象的编程语言,具有跨平台性、安全性、稳定性和高效性。在这个项目中,开发者选择Java作为实现进程调度算法的工具,因为Java提供了一套完整的类库和强大的内存管理...

Global site tag (gtag.js) - Google Analytics