java-线程(一)
1.进程与线程的区别
多个进程的内部数据和状态都是完全独立的,而多个线程是共享一块内存空间和一组系统资源,有可能互相影响。多线程程序比多进程程序需要更少的管理费用。进程是重量级的任务,需要分配他们的单独的地址空间。进程间通信是昂贵和受限的,进程间的切换也是很需要花费的。另一方面,线程是轻量级的选手,他们共享相同的地址空间并且共享同一个进程。线程间通信是便宜的,县城建的转化也是低成本的
线程本身的数据通常只有寄存器数据,以及一个程序执行时使用的堆栈,所以线程的切换比进程切换的负担要小。
比如:搬砖(一个进程),一个人搬,则是一个线程,是顺序执行的。五个人搬,则是五个线程。
2.什么是多线程
多线程是指在单个程序中可以同时运行不同的线程来执行的不同的任务。线程是程序内的顺序控制流,只能使用分配给程序的资源和环境。多线程的目的:最大限度的利用CPU。
例子:当程序启动运行时,就自动产生一个线程,主方法main就在这个主线程上面运行。
3.进程:执行中的程序(程序是静态的,进程是动态的),一个进程可以包含一个或者多个线程(Thread)。
4.线程的实现
在java中通过run方法为线程指明要完成的任务,有两种技术来为线程提供run方法。
1)集成Thread类并重写run方法,然后通过srart方法来启动线程,start方法首先为线程的执行准备好系统资源,然后调用run方法。当一个类集成了Thread类,就变成了一个线程
2)通过定义实现Runnable接口的类进而实现run方法,必须通过start方法来启动线程。
简单例子:
public class ThreadTest
{
public static void main(String[] args)
{
Thread1 t1 = new Thread1("first thread");
Thread1 t2 = new Thread1("second thread"); System.out.println(t1.getName());
System.out.println(t2.getName()); t1.start();
t2.start();
}
} class Thread1 extends Thread
{
public Thread1(String name)
{
super(name);
} @Override
public void run()
{
for(int i = 0; i < 100; i++)
{
System.out.println("hello world: " + i);
}
}
} class Thread2 extends Thread
{
public Thread2(String name)
{
super(name);
} @Override
public void run()
{
for(int i = 0; i < 100; i++)
{
System.out.println("welcome: " + i);
}
}
}
public class ThreadTest2
{
public static void main(String[] args)
{
// Thread t1 = new Thread(new Runnable()
// {
// @Override
// public void run()
// {
// for(int i = 0; i < 100; i++)
// {
// System.out.println("hello :" + i);
// }
// }
// });
//
// t1.start(); Thread t1 = new Thread(new MyThread()); t1.start(); Thread t2 = new Thread(new MyThread2()); t2.start(); }
} class MyThread implements Runnable
{
@Override
public void run()
{
for(int i = 0; i < 100; i++)
{
System.out.println("hello :" + i);
}
}
} class MyThread2 implements Runnable
{
@Override
public void run()
{
for(int i = 0; i < 100; i++)
{
System.out.println("welcome: " + i);
} }
}
Thread 和 Runnable的区别
1.Thread类也实现了Runnable接口,因此实现了Runnable接口中的run方法。
2.当生成一个线程对象时,如果没有为其设定名字,那么线程对象的名字将使用如下形式:Thread-number
3.当使用Thread生成线程对象时,我们需要重写run方法,因为Thread类的run方法此时什么也不做
4.当使用Runnable实现线程对象时,需要实现Runnable接口中的run方法,然后使用new Thread(new MyThread())来生成线程对象,这时的线程对象的run方法就会调用Muthread类的run发放,这样就使用我们自己编写的run方法了
线程的生命周期
1)创建状态
2)可运行状态
3)不可运行状态:sleep(long millis);线程调用wait方法等待特定条件的满足;线程输入、输出阻塞。
4)消亡状态

返回可运行状态条件:处于睡眠状态的线程在制定的时间过去后;如果线程在等待某一条件,另一个对象必须通过notify()或notifyAll()方法通知等待线程条件的改变;如果线程是因为输入/输出阻塞,等待输入/输出完成。
为什么要引入同步机制
在多线程环境中,可能会有两个甚至更多的线程试图访问一个有限的资源,必须对这种潜在资源冲突进行预防。
解决方法:在线程使用一个资源时为其加锁即可。访问资源的第一个线程为其加上锁后,其他线程便不能再使用那个资源,除非被解锁。
synchronized关键字:当synchronized关键字修改一个方法的时候,该方法叫做同步方法。
java中的每一个对象都有一个锁(lock)或者叫做监视器(monitor),当访问某个对象的synchronized方法时,表示将该对象上锁,此时其他任何线程都无法再次访问该synchronized方法了,直到之前的那个线程执行方法完毕后(或者抛出异常),那么将该对象的锁释放掉,其他线程才能有可能再去访问该synchronized方法。
public class ThreadTest4
{
public static void main(String[] args)
{
Example example = new Example(); Thread t1 = new TheThread(example); example = new Example(); Thread t2 = new TheThread2(example); t1.start();
t2.start();
}
} class Example
{
public synchronized static void execute()
{
for(int i = 0; i < 20; i++)
{
try
{
Thread.sleep((long)(Math.random() * 1000));
}
catch (InterruptedException e)
{
e.printStackTrace();
} System.out.println("hello: " + i);
}
} public synchronized static void execute2()
{
for(int i = 0; i < 20; i++)
{
try
{
Thread.sleep((long)(Math.random() * 1000));
}
catch (InterruptedException e)
{
e.printStackTrace();
} System.out.println("world: " + i);
}
}
} class TheThread extends Thread
{
private Example example; public TheThread(Example example)
{
this.example = example;
} @Override
public void run()
{
this.example.execute();
}
} class TheThread2 extends Thread
{
private Example example; public TheThread2(Example example)
{
this.example = example;
} @Override
public void run()
{
this.example.execute2();
}
}
synchronized使用
java-线程(一)的更多相关文章
- Java线程并发:知识点
Java线程并发:知识点 发布:一个对象是使它能够被当前范围之外的代码所引用: 常见形式:将对象的的引用存储到公共静态域:非私有方法中返回引用:发布内部类实例,包含引用. 逃逸:在对象尚未准备 ...
- Java线程的概念
1. 计算机系统 使用高速缓存来作为内存与处理器之间的缓冲,将运算需要用到的数据复制到缓存中,让计算能快速进行:当运算结束后再从缓存同步回内存之中,这样处理器就无需等待缓慢的内存读写了. 缓 ...
- Java 线程池框架核心代码分析--转
原文地址:http://www.codeceo.com/article/java-thread-pool-kernal.html 前言 多线程编程中,为每个任务分配一个线程是不现实的,线程创建的开销和 ...
- 细说进程五种状态的生老病死——双胞胎兄弟Java线程
java线程的五种状态其实要真正高清,只需要明白计算机操作系统中进程的知识,原理都是相同的. 系统根据PCB结构中的状态值控制进程. 单CPU系统中,任一时刻处于执行状态的进程只有一个. 进程的五种状 ...
- 【转载】 Java线程面试题 Top 50
Java线程面试题 Top 50 不管你是新程序员还是老手,你一定在面试中遇到过有关线程的问题.Java语言一个重要的特点就是内置了对并发的支持,让Java大受企业和程序员 的欢迎.大多数待遇丰厚的J ...
- 第24章 java线程(3)-线程的生命周期
java线程(3)-线程的生命周期 1.两种生命周期流转图 ** 生命周期:**一个事物冲从出生的那一刻开始到最终死亡中间的过程 在事物的漫长的生命周期过程中,总会经历不同的状态(婴儿状态/青少年状态 ...
- 第23章 java线程通信——生产者/消费者模型案例
第23章 java线程通信--生产者/消费者模型案例 1.案例: package com.rocco; /** * 生产者消费者问题,涉及到几个类 * 第一,这个问题本身就是一个类,即主类 * 第二, ...
- 第22章 java线程(2)-线程同步
java线程(2)-线程同步 本节主要是在前面吃苹果的基础上发现问题,然后提出三种解决方式 1.线程不安全问题 什么叫线程不安全呢 即当多线程并发访问同一个资源对象的时候,可能出现不安全的问题 对于前 ...
- 第21章 java线程(1)-线程初步
java线程(1)-线程初步 1.并行和并发 并行和并发是即相似又有区别: 并行:指两个或者多个事件在同一时刻点发生. 并发:指两个或多个事件在同一时间段内发生 在操作系统中,并发性是指在一段事件内宏 ...
- [转]Java线程安全总结
最近想将java基础的一些东西都整理整理,写下来,这是对知识的总结,也是一种乐趣.已经拟好了提纲,大概分为这几个主题: java线程安全,java垃圾收集,java并发包详细介绍,java profi ...
随机推荐
- 洛谷1967货车运输 即 NOIP2013 DAY1 T3
题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过车辆限重的情况下,最多 ...
- IntelliJ IDEA中Spring Boot项目使用spring-boot-devtools无法实现热部署/热更新的问题解决
这个设置真的和Eclipse有很大区别,Eclipse中只要运行之后就可实现修改文件自动重启.但IDEA不太一样,需要做如下配置: 前提: 1.添加spring-boot-devtools到POM. ...
- XCode 4.3 Unable to load persistent store UserDictionary.sqlite 以及 ios simulator failed to install the application
I have been working on an iOS app for some time, all of a sudden I am getting the following crash ev ...
- 邁向IT專家成功之路的三十則鐵律 鐵律二十四:IT人歲月增長之道-智慧
老子曾經在道德經中提到:「以道為本而繁守不失的,可算是長久.身雖死亡而精神不朽的,可算是長壽」.人在世間最悲哀的莫過於老死,但最可貴的則莫過於智慧.只是人的智慧不一定會隨著年齡的增長與歲月的流逝而成長 ...
- linux安装开源邮件服务器iredmail的方法:docker
直接安装的方法,参考网文,我不介绍.本文介绍的是快速的方法:docker 使用镜像源:https://hub.docker.com/r/lejmr/iredmail/,因为pull的数量最多 直接 d ...
- PPAPI插件的动态创建、改动、删除
一旦你完毕了PPAPI插件的开发,实际使用时可能会有下列需求: 动态创建PPAPI插件 删除PPAPI插件 改变PPAPI插件的尺寸 实现起来非常easy,从JS里直接訪问DOM(BOM)就可以.以下 ...
- innerHTML outerHTML innerText
迁移时间--2017年10月31日14:52:59 Author:Marydon UpdateTime--2017年1月15日20:33:03innerHTML,outerHTML与innerTe ...
- linux下的环境文件设置说明
工作环境设置文件 环境设置文件有两种:系统环境设置文件 和 个人环境设置文件 1.系统中的用户工作环境设置文件: 登录环境设置文件:/etc/profile 非登录环境设置文件: ...
- Linux 学习之虚拟机下的网络连接
参考资料: http://wenku.baidu.com/link?url=_55RWvvBKQDoZjQSo-HQ3TdmLIzX1zkA_g1znCw0IXkwvxbxMiA3KfpyaL-lhv ...
- mysql binlog配置详解
关闭binlog,注释掉mysql配置文件中的log-bin=mysql-bin即可 baidu zone - 关闭binlog方法 cnblogs - linux下mysql配置文件my ...