
线程
kjfcpua
这个作者很懒,什么都没留下…
展开
-
java线程池的原理与实现
java线程池的原理与实现 [分享]Java 线程池的原理与实现2008-07-18 14:53------------------------------------------------------------------------------------------------ 这几天主要是狂看源程序,在弥补了一些以前知识空白的同时,也学会了不少新的知识(比如 NIO),或者称为新技转载 2009-09-24 14:48:00 · 885 阅读 · 1 评论 -
线程同步
我们可以在计算机上运行各种计算机软件程序。每一个运行的程序可能包括多个独立运行的线程(Thread)。线程(Thread)是一份独立运行的程序,有自己专用的运行栈。线程有可能和其他线程共享一些资源,比如,内存,文件,数据库等。当多个线程同时读写同一份共享资源的时候,可能会引起冲突。这时候,我们需要引入线程“同步”机制,即各位线程之间要有个先来后到,不能一窝蜂挤上去抢作一团。转载 2009-11-26 13:42:00 · 562 阅读 · 0 评论 -
线程同步简述
1:线程同步就是线程排队。同步就是排队。线程同步的目的就是避免线程“同步”执行。2: “共享”这两个字。只有共享资源的读写访问才需要同步。如果不是共享资源,那么就根本没有同步的必要。 3:只有“变量”才需要同步访问。如果共享的资源是固定不变的,那么就相当于“常量”,线程同时读取常量也不需要同步。至少一个线程修改共享资 源,这样的情况下,线程之间就需要同步。4:多个线程访问原创 2009-11-26 13:47:00 · 1406 阅读 · 0 评论 -
Java 理论与实践: 线程池与工作队列
贴在我们多线程 Java 编程论坛上最常见的问题之一是“怎样创建线程池?”。几乎在每个服务器应用程序中都会出现线程池和工作队列问题。本文中,Brian Goetz 探讨了线程池的动机、一些基本实现和调优技术以及一些要避免的常见危险。为什么要用线程池?诸如 Web服务器、数据库服务器、文件服务器或邮件服务器之类的许多服务器应用程序都面向处理来自某些远程来源的大量转载 2009-11-23 20:12:00 · 671 阅读 · 0 评论 -
Java多线程编程详解
一、理解多线程 多线程是这样一种机制,它允许在程序中并发执行多个指令流,每个指令流都称为一个线程,彼此间互相独立。线程又称为轻量级进程,它和进程一样拥有独立的执行控制,由操作系统负责调度,区别在于线程没有独立的存储空间,而是和所属进程中的其它线程共享一个存储空间,这使得线程间的通信远较进程简单。 具体到java内存模型,由于Java被设计为跨平台的语言,在内存管理上转载 2010-01-17 16:10:00 · 870 阅读 · 0 评论 -
如何聪明地使用锁
锁(lock)作为用于保护临界区(critical section)的一种机制,被广泛应用在多线程程序中。无论是Java 语言中的 synchronized 关键字,还是 java.util.concurrent 包中的ReentrantLock,都是多线程应用开发人员手中强有力的工具。但是强大的工具通常是把双刃剑,过多或不正确的使用锁,会导致多线程应用的性能下降。这种问题在多核转载 2009-11-24 18:16:00 · 686 阅读 · 0 评论 -
探索 Java 同步机制
本文从典型的 Monitor Object 设计模式入手,从一个新的视角,来探讨 Java 语言的同步机制。本文将从两个方面进行阐述:使用 C++ 语言来描述 Monitor Object 设计模式。Java 对于这样一个典型的模式做了很好的语言层面的封装,因此对于 Java的开发者来说,很多关于该模式本身的东西被屏蔽掉了。本文试图使用 Native C++ 语言转载 2009-11-24 18:17:00 · 725 阅读 · 0 评论 -
java并发编程实践笔记
1, 保证线程安全的三种方法: a, 不要跨线程访问共享变量b, 使共享变量是final类型的c, 将共享变量的操作加上同步 2, 一开始就将类设计成线程安全的, 比在后期重新修复它,更容易. 3, 编写多线程程序, 首先保证它是正确的, 其次再考虑性能. 4, 无状态或只读对象永远是线程安全的. 5, 不要将一个共享变量裸露在多线程环转载 2009-11-19 16:40:00 · 636 阅读 · 0 评论 -
一个简单的Thread缓冲池的实现
在应用中,我们常常需要Thread缓冲池来做一些事以提高程序的效率和并发性。本文演示了如何利用Queue这种数据结构实现一个简单的Thread缓冲池。 一个Thread缓冲池可以设计成以下这样:缓冲池由几个工作Thread和一个Queue组成,Client负责把任务转载 2009-11-13 19:54:00 · 659 阅读 · 0 评论 -
基于生产-消费者模式的任务异步线程池设计与实现
昨天上来看看,看到有个童鞋发了篇关于线程池的实现的帖子,也引来了不少讨论。呵呵,初步看了下,那个线程池的设计与实现还是比较初级,并且存在的问题还是蛮多的。刚好,前两者,为一个项目设计实现了一个基于生产-消费者模式的任务异步处理组件,中间用到了线程池,发上来,供一些童鞋学习参考下。 有些童鞋可能会说,在JDK1.5后就带了ExecutorService这样的线程池,干嘛还转载 2009-09-24 20:06:00 · 2836 阅读 · 1 评论 -
线程池的介绍及简单实现
线程池的介绍及简单实现 文档选项<!--<! document.write(打印本页);// >// --> 打印本页 <!--<! document.write(将此页作为电子邮件发送)原创 2009-09-24 15:44:00 · 644 阅读 · 0 评论 -
JAVA线程池的简单实现及优先级设置
我们大家都知道,在处理多线程服务并发时,由于创建线程需要占用很多的系统资源,所以为了避免这些不必要的损耗,通常我们采用线程池来解决这些问题。 线程池的基本原理是,首先创建并保持一定数量的线程,当需要使用线程时,我们从池中取得线程,再将需要运行的任务交给线程进行处理,当任务完成后再将其释放回池中。 下面,我给出一个很简单的实现模型,仅供参考。 ThreadPool.java转载 2009-12-04 12:04:00 · 826 阅读 · 0 评论