本文主要是介绍疯狂JAVA讲义---第十六章:多线程(上),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
并发现象在现实生活中大量存在,人体(消化、运动),计算机(同时运行多种程序)。
多线程—在一个程序中实现并发编程语言一般提供了串行程序设计的方法
计算机的并发能力由操作系统提供,Java在语言级提供多线程并发的概念。
线程是比进程单位更小的执行单位,在形式上同进程十分相似——都是用一个顺序执行的语句序列来完成特定的功能。
线程没有入口,也没有出口,因此其自身不能自动运行,而必须栖身于某一进程之中,由进程触发执行。
在系统资源的使用上,属于同一进程的所有线程共享该进程的系统资源,但是线程之间切换的速度比进程切换要快得多。
线程的状态与生命周期:
Java类库提供了java.lang.Thread类来创建并控制所创建的线程。eg
注意:使用继承Thread类的方法不能实现多线程的共享实例变量
要共享变量,就要说到下面的实现runnable接口来实现多线程。eg
一个至关重要的方法——public void run(),这个方法称为线程体,它是整个线程的核心,线程所要完成任务的代码都定义在线程体中,实际上不同功能的线程之间的区别就在于它们线程体的不同。
多线程的基本控制
1.启动和终止
start()使线程进入就绪状态,run()方法完成自然终止。也可用stop()方法。
2.检测线程状态
isAlive()不能判断是运行还是阻塞。
3.suspend和stop(基本不用,会引起线程不安全)
4.join()方法
使当前正在运行的线程暂停,等待调用该方法的线程结束后再恢复运行。eg
5.yield()方法
如果在就绪队列中有其他同优先级的线程,yield()把调用者放入就绪队列尾,并允许其他线程运行。
Java线程优先级用1~10表示,10最高,main线程默认为5,下面看如何使用和效果,eg
线程同步
在处理多线程问题时,当多个线程同时访问一些资源时,特别是一个线程需要修改某个资源,如果不能协调,就不能保证运行结果的正确性。
举例:栈操作,如果一个线程要进栈,而另一个线程要出栈。
Java用synchronized来给共享资源加锁。
如果用synchronized修饰一个对象,则该对象在任何时刻只能有一个线程访问。
如果用synchronized修饰一个方法,则该方法在任何时刻只能有一个线程访问。eg
synchronize后的account是同步监视对象
这篇关于疯狂JAVA讲义---第十六章:多线程(上)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!