摘要: 浅谈java内存模型不同的平台,内存模型是不一样的,但是jvm的内存模型规范是统一的。其实java的多线程并发问题最终都会反映在java的内存模型上,所谓线程安全无非是要控制多个线程对某个资源的有序访问或修改。总结java的内存模型,要解决两个主要的问题:可见性和有序性。我们都知道计算机有高速缓存的存在,处理器并不是每次处理数据都是取内存的。JVM定义了自己的内存模型,屏蔽了底层平台内存管理细节,对于java开发人员,要清楚在jvm内存模型的基础上,如果解决多线程的可见性和有序性。那么,何谓可见性? 多个线程之间是不能互相传递数据通信的,它们之间的沟通只能通过共享变量来进行。Java内存模型( 阅读全文
posted @ 2013-04-28 16:41 hold su 阅读(242) 评论(0) 推荐(0) 编辑
摘要: 通过铁路售票程序来理解实现多线程的两种方法:通过java.lang.Thread类和通过Runnable接口 java中有两种实现多线程的方式。一是直接继承Thread类,二是实现Runnable接口。那么这两种实现多线程的方式在应用上有什么区别呢? 为了回答这个问题,我们可以通过编写一段代码来进行分析。我们用代码来模拟铁路售票系统,实现通过四个售票点发售某日某次列车的100张车票,一个售票点用一个线程表示。 我们首先这样编写这个程序:[java]view plaincopypublicclassThreadDome1{ publicstaticvoidmain(String[]args... 阅读全文
posted @ 2013-04-28 11:38 hold su 阅读(415) 评论(0) 推荐(0) 编辑
摘要: run():线程的执行逻辑start():启动线程yield():暂定线程的执行,允许其它线程竞争CPU,常用于具有同等优先级的线程之间的竞争,适用于不支持时间分片的操作系统之间的线程处理。sleep(long millis):线程休眠,暂停执行,但是不交出临界区的锁。stop():kill一个线程,但是通常通过线程内的循环条件来结束一个线程。setPriority(int weight):设置线程的优先级(1->10),值越高,优先级越高,一般是5,且子线程与母线程具有同等的优先级和线程属性(是否为前后台线程)。setDaemon(true):在start()方法前执行,将该线程设置为 阅读全文
posted @ 2013-04-28 11:26 hold su 阅读(194) 评论(0) 推荐(0) 编辑
摘要: 在这里需要明确的是:无论采用继承Thread类还是实现Runnable接口来实现应用程序的多线程能力,都需要在该类中定义用于完成实际功能的run方法,这个run方法称为线程体(Thread Body)。按照线程体在计算机系统内存中的状态不同,可以将线程分为创建、就绪、运行、睡眠、挂起和死亡等类型。这些线程状态类型下线程的特征为: 创建状态:当利用new关键字创建线程对象实例后,它仅仅作为一个对象实例存在,JVM没有为其分配CPU时间片等线程运行资源; 就绪状态:在处于创建状态的线程中调用start方法将线程的状态转换为就绪状态。这时,线程已经得到除CPU时间之外的其它系统资... 阅读全文
posted @ 2013-04-28 10:49 hold su 阅读(506) 评论(0) 推荐(0) 编辑