1.0 高并发之线程和进程
2018-12-04 07:04:51来源:博客园 阅读 ()
一、多线程
1、1 线程与进程区别
进程:每个正在系统上运行的程序都是一个进程。每个进程包含一到多个线程。
线程:线程是一组指令的集合,或者是程序的特殊段,它可以在程序里独立执行。
总结:进程是所有线程的集合,每一个线程是进程中的一条执行路径。多线程的好处是可以提高程序的效率。
一个应用系统可以多个进程:进程中一定有一个主线程(JAVA中Main函数)。线程是一个进程执行顺序,流程,路径,并且每个线程不影响。
1、2 生活中实例:
迅雷种子多个下载,买票系统,应用系统,Ajax异步上传。
1、3 实现多线程的方式
同步执行:单线程(同一时刻只能执行一个方法,时间相加)
异步执行:多线程(同一时刻同时执行多个方法,不相互影响,时间随最后执行完时间结束)
实现Runnable接口比继承Thread类好,因为接口可以多继承。
开始执行线程 开启线程不是调用run方法,而是start方法
创建方法: 1、第一种继承Thread类 重写run方法、范例代码:注意 开启线程不是调用run方法,而是start方法
package com.lele.JavaAll1203Test;
/**
* @author LIULE
* @version v0.1
* @classDesc 创建多线程例子(重写Thread的run方法)
*/
class CreateThrea extends Thread{
public void run(){
for( int i = 0;i<=200;i++){
System.out.println("i的值为"+i);
}
}
}
public class Test01Threath {
public static void main(String[]args){
System.out.println("多线程createThread开始");
CreateThrea t = new CreateThrea();
System.out.println("开始执行多线程");
t.start();
for( int i = 0;i<=200;i++){
System.out.println("MAIN"+i);
}
System.out.println("多线程createThread结束");
}
}
2、实现Runnable接口,重写run方法,代码范例
/**
* @author LIULE
* @version v0.1
* @classDesc 创建多线程例子(实现Runnable接口)
*/
public class Test02Runnable {
public static void main(String[]args){
System.out.println("创建一个多线程---");
creatRunnable c = new creatRunnable();
System.out.println("多线程开始调用---");
Thread thread = new Thread(c);
thread.start();
for(int i = 0 ; i <= 200 ;i++ ){
System.out.println("i的主方法的值为"+i);
}
System.out.println("多线程调用结束--");
}
}
class creatRunnable implements Runnable{
@Override
public void run(){
for(int i = 0 ; i <= 200 ;i++ ){
System.out.println("i的子线程值为"+i);
}
}
}
3、使用匿名内部类
public class Test03InNoname {
public static void main(String[]args){
System.out.println("多线程开始");
Thread thread = new Thread(new Runnable() {
@Override
public void run() {
for ( int i = 0; i < 20;i++){
System.out.println("内部子线程i"+i);
}
}
});
thread.start();
for ( int i = 0; i < 20;i++){
System.out.println("内部主线程i"+i);
}
}
}
线程常用API的方法:
start()启动线程
currentThread()获取当前线程对象
getID()获取当前线程ID Thread-编号 该编号从0开始
getName()获取当前线程名称
sleep(long mill)休眠线程
Stop()停止线程,(不安全,已不使用)
二、守护线程
Java中有两种线程,一种是用户线程(非守护线程,用户线程是指用户自定义创建的线程,主线程停止,用户线程不会停止)
另一种是守护线程(和主线程一起销毁GC回收线程)。守护线程当进程不存在或主线程停止,守护线程也会被停止。
使用setDaemon(true)方法设置为守护线程
三、多线程状态
线程从创建、运行到结束总是处于下面五个状态之一:新建状态(ew Thread(r))、就绪状态(start()方法)、运行状态(真正开始执行run()方法)、
阻塞状态 线程运行过程中,可能由于各种原因进入阻塞状态:
1>线程通过调用sleep方法进入睡眠状态;
2>线程调用一个在I/O上被阻塞的操作,即该操作在输入输出操作完成之前不会返回到它的调用者;
3>线程试图得到一个锁,而该锁正被其他线程持有;
4>线程在等待某个触发条件;
死亡状态,需要使用isAlive方法
1) run方法正常退出而自然死亡,
2) 一个未捕获的异常终止了run方法而使线程猝死。
四、JOIN方法
join作用是让其他线程变为等待,
t1.join();// 让其他线程变为等待,直到当前t1线程执行完毕,才释放。
thread.Join把指定的线程加入到当前线程,可以将两个交替执行的线程合并为顺序执行的线程。比如在线程B中调用了线程A的Join()方法,直到线程A执行完毕后,才会继续执行线程B。join方法写在相应的下一个执行的方法中。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇:Lucene的基本使用
- 最详细的java多线程教程来了 2020-06-08
- 系统化学习多线程(一) 2020-06-08
- 多线程:生产者消费者(管程法、信号灯法) 2020-06-01
- 如何合理地估算线程池大小? 2020-05-31
- 那些面试官必问的JAVA多线程和并发面试题及回答 2020-05-28
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash