Day24_多线程第一天
1、线程
1、概述
package cn.itcast.createThread;class MyThread extends Thread{@Overridepublic void run() {System.out.println("线程在运行");}}public class Demo1 {public static void main(String[] args) {MyThread mt = new MyThread();//启动线程mt.start();}}
package cn.itcast.createThread;class MyRunnable implements Runnable {@Overridepublic void run() {System.out.println("启动了");}}public class Demo {public static void main(String[] args) {//第一步:创建实现了Runnable接口的子类对象MyRunnable mr = new MyRunnable();//第二步:通过刚创建的mr对象创建Thread对象Thread thread = new Thread(mr);//第三步:启动线程thread.start();}}
public class MyThread extends Thread{@Overridepublic void run() {//设置线程名Thread.currentThread().setName("线程A");System.out.println(Thread.currentThread().getName());}public static void main(String[] args) {MyThread mt = new MyThread();mt.start();}}
package cn.itcast.create;public class MyRunnable implements Runnable{@Overridepublic void run() {//设置线程名Thread.currentThread().setName("线程A");System.out.println(Thread.currentThread().getName());}public static void main(String[] args) {Thread t = new Thread(new MyRunnable());t.start();}}

2、卖票案例(掌握)
1、有问题的代码(出现错误票)
/**卖票程序*/public class TicketRunnable implements Runnable{private int tickets = 100;@Overridepublic void run() {while(true){if(tickets > 0){try {Thread.sleep(1000);//必须加这个,由于CPU太快否则不一定出现负数-----语句1} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName()+"正在卖第"+tickets--+"张的票");---语句2}else{break;//必须加这个,否则无法跳出循环,造成死机}}}}/**测试类*/public class TicketDemo {public static void main(String[] args) {TicketRunnable runnable = new TicketRunnable();Thread t1 = new Thread(runnable, "窗口1");Thread t2 = new Thread(runnable, "窗口2");Thread t3 = new Thread(runnable, "窗口3");t1.start();t2.start();t3.start();}}
修改后的代码/卖票案例完整代码public class TicketRunnable implements Runnable {private int tickets = 50;private Object lock = new Object();@Overridepublic void run() {while (true) {synchronized (lock) {if (tickets > 0) {try {Thread.sleep(100);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName()+ "正在卖第" + tickets-- + "张的票");} else {break;}}}}}
3、锁,同步代码块,同步方法(这块记住结论就好,根据自身情况自行测试)
4、死锁(掌握)
/**锁对象*/public class Lock {public static final Object LOCK_A = new Object();public static final Object LOCK_B = new Object();}/**线程1*/public class Thread1 extends Thread {@Overridepublic void run() {synchronized (Lock.LOCK_A) {System.out.println("我是线程1,已经拿到A锁,将要去哪B锁");synchronized (Lock.LOCK_B) {System.out.println("我是线程1,成功拿到B锁");}}}}/**线程2*/public class Thread2 extends Thread {@Overridepublic void run() {synchronized (Lock.LOCK_B) {System.out.println("我是线程2,已经拿到B锁,将要去哪A锁");synchronized (Lock.LOCK_A) {System.out.println("我是线程2,成功拿到A锁");}}}}/**测试代码*/public class Test {public static void main(String[] args) {Thread1 t1= new Thread1();Thread2 t2= new Thread2();t1.start();t2.start();}}- //注意:以上代码可能不会死锁,如果必须产生死锁效果将run()方法中的所有内容用while(true)包裹起来
5、休眠线程(掌握)
package cn.itcast.createThread;public class MyThread extends Thread{@Overridepublic void run() {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}}}
6、守护线程
package cn.itcast.createThread;public class MyThread extends Thread{@Overridepublic void run() {while(true){System.out.println("xx");}}public static void main(String[] args) throws Exception {MyThread mt = new MyThread();mt.setDaemon(true);mt.start();//主线程在1S后结束,结束后mt线程也随之停止Thread.sleep(1000);}}
7、加入线程
package cn.itcast.createThread;public class MyThread extends Thread{@Overridepublic void run() {while(true){System.out.println("xx");}}public static void main(String[] args) throws Exception {MyThread mt = new MyThread();mt.start();mt.join();//因为mt线程被设置为加入线程,所以只有当mt线程执行完后你好才会执行System.out.println("你好");}}
8、设置线程优先级
线程默认优先级是5。范围是1-10
13、今天必须掌握的内容,面试题,笔试题。(掌握这个就可以放心学习后面的知识了)
Day24_多线程第一天的更多相关文章
- “全栈2019”Java多线程第一章:认识多线程
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...
- 秒杀多线程第一篇 多线程笔试面试题汇总 ZZ 【多线程】
http://blog.csdn.net/morewindows/article/details/7392749 系列前言 本系列是本人参加微软亚洲研究院,腾讯研究院,迅雷面试时整理的,另外也加入一些 ...
- 5天不再惧怕多线程——第一天 尝试Thread
随笔 - 218 文章 - 1 评论 - 3819 5天不再惧怕多线程——第一天 尝试Thread 原本准备在mongodb之后写一个lucene.net系列,不过这几天用到多线程时才发现自己 ...
- Java学习多线程第一天
内容介绍 Thread 线程创建 线程池 线程状态图 1 多线程 1.1 多线程介绍 学习多线程之前,我们先要了解几个关于多线程有关的概念. 进程:进程指正在运行的程序.确切的来说,当一个程序 ...
- Abap 多线程
http://scn.sap.com/thread/18844 SAP ABAP 实现多线程 第一步:初始化server group ,server group 可以用RZ12进行维护,参数支 ...
- 跟着刚哥梳理java知识点——多线程(十六)
创建多线程第一种方式:① 继承:继承Thread.② 重写:重写Thread类的run()方法③ 创建:创建一个子类的对象④ 调用:调用线程的start()方法,启动此线程,调用run()方法 cla ...
- Java 多线程(一)—— 概念的引入
并发和并行 并行:指两个或多个时间在同一时刻发生(同时发生): 并发:指两个或多个事件在一个时间段内发生. 在操作系统中,安装了多个程序,并发指的是在一段时间内宏观上有多个程序同时运行,这在单 C ...
- 多线程之 Thread类
一.多线程第一种方式的实现步骤(继承Thread类) 代码演示: 1.定义MyThread类,继承Thread类 2.重写了里面的run方法,在run方法中定义线程要执行的任务 public clas ...
- 收藏:c语言的多线程同步
1.<秒杀多线程第一篇 多线程笔试面试题汇总> 2.<秒杀多线程第二篇 多线程第一次亲密接触 CreateThread与_beginthreadex本质区别> 3.<秒杀 ...
随机推荐
- Git 仓库和记录操作到仓库
Git 配置好了,来 clone 个或者新建个仓库来试试, $ git clone git@github.com:git/git.git 把 Git 的源码克隆下来,克隆会自动创建本地仓库,并创建本地 ...
- HDU 4938 Seeing People(2014 Multi-University Training Contest 7)
思路:根据出发时间把点往速度反方向移动 t*v的 的距离这样就可以当成 全部点一起出发,再把y轴上的点固定不动相当于x轴的点向(-v2,v1)方向移动 .可以把所有点映射到x轴上进行统计即可(要记住同 ...
- 一款新的PYTHON数据科学利器:yhat
偶然看文章发现的一个新的python IDE,外表很清新,也很新颖. https://www.yhat.com/products/rodeo 看图说话,软件的布局确实很新颖,和Notebook类似,也 ...
- android 在使用studio 编写百度地图中遇到APP Scode码校验失败 问题
直接用打包出来的apk查看签名,具体如下: 1) 将apk修改后缀为 .zip文件后解压: 2) 进入解压后的META-INF目录,该目录下会存在文件CERT.RSA 3) 在该目录下打开cmd,输入 ...
- MYSQL5.7无法启动服务原因及解决方案
mysql5.7安装完成后,想要把它发布成windows服务: 首先,应该配置新的配置文件,然后将cmd打开到安装目录的bin文件,键入: mysqld --default-file="D: ...
- shared_ptr和多线程
前一篇文章写得实在太挫,重新来一篇. 多线程环境下生命周期的管理 多线程环境下,跨线程对象的生命周期管理会有什么挑战?我们拿生产者消费者模型来讨论这个问题. 实现一个简单的用于生产者消费者模型的队列 ...
- 如何处理C#的HttpWebResponse的GetResponse中的超时异常
程序中,有时会遇到超时的异常,需要进行处理,用一般的try...catch(Exception ex)...会发现ex没有status属性,此时使用WebException捕获异常: try { re ...
- centos7网络设置
1.设置虚拟机网络连接方式 2.启动改为从驱动启动 3.启动虚拟机,使用命令 ip addr 查看ip,发现网卡配置为 eno16777736 如果找不到网卡配置文件,请返回安装过程,查看是否正确选择 ...
- goldengate for big data 12.2.0.1.1新增功能
新格式支持:包括Avro OCF和HDFS顺序文件,OGG现在支持将数据写入Avro对象容器(Object container format)和HDFS顺序文件 支持Hadoop平台元数据或DDL更新 ...
- Linux代码的重用与强行卸载Linux驱动
(一)Linux代码的重用 重用=静态重用(将要重用的代码放到其他的文件的头文件中声明)+动态重用(使用另外一个Linux驱动中的资源,例如函数.变量.宏等) 1.编译是由多个文件组成的Linux驱动 ...