package com.phone.week5.day1;
/*
* 第一种创建线程的方式
* 继承Thread类
* 重写run方法,就是你这个线程所有执行的代码都放在run方法里
* 开启线程的方法是start()方法
*
* 当你创建一个线程之后,你要调用start方法来开启这个线程,就会自动执行run方法里的内容
*
* 使用一个线程分为四个步骤:
* 1.定义一个线程,同时指明这个线程所要执行的代码,也就是要完成的功能,(这些功能是写在run方法里的)
* 2.创建线程对象
* 3.启动线程(调用start方法)
* 4.终止线程(也就是线程执行完毕)
* 线程常用的方法:
* 通过Thread.currentThread()方法可以返回当前正在执行的线程对象
* getName():可以得到线程的名字
*/
//创建两个线程,一个线程计算100之内的偶数之和,一个线程计算100之内的奇数之和
//创建三个线程,一个复制图片,一个复制文件,一个复制音乐,要同时复制
/*
* 线程的状态,也叫生命周期,大的来分就分四种
* 1.新建状态:Demo d = new Demo(“one”);就是创建了一个线程对象
* 2.可运行状态:就是调用了start()方法
* 3.阻塞状态:因为调用了某些方法变成了不可运行的状态
* 4.死亡状态:执行完run方法后或者在执行run方法中出现了异常没有捕获成功都会进入死亡状态
* 所以线程的生命周期指:从线程的创建–》启动—>运行—>结束
*
*/
public class Test {
public static void main(String[] args) {
Demo d = new Demo("one");
d.start();
System.out.println("d这个线程的状态"+d.isAlive());
Demo d2= new Demo("two");
d2.start();
for (int i = 0; i < 100; i++) {
System.out.println(Thread.currentThread().getName()+"\t"+i);
}
System.out.println("d这个线程的状态"+d.isAlive());
}
}
class Demo extends Thread{
public Demo(String name){
super(name);
}
@Override
public void run() {
for (int i = 0; i < 100; i++) {
System.out.println(Thread.currentThread().getName()+”\t”+i);
}
}
}
package com.phone.week5.day1;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
public class Test2 {
public static void main(String[] args) {
CopyImage ci = new CopyImage("IMAGE");
ci.start();
for (int i = 0; i < 1000; i++) {
System.out.println(Thread.currentThread().getName()+"--------------------------:"+i);
}
}
}
class CopyImage extends Thread{
public CopyImage(String name) {
super(name);
}
@Override
public void run() {
copyImage(new File(“d:\image.png”));
}
public void copyImage(File file){
FileInputStream fis = null;
BufferedInputStream bis = null;
DataInputStream dis = null;
FileOutputStream fos = null;
BufferedOutputStream bos = null;
DataOutputStream dos = null;
try {
fis = new FileInputStream(file);
bis = new BufferedInputStream(fis);
dis = new DataInputStream(bis);
fos = new FileOutputStream("my.png");
bos = new BufferedOutputStream(fos);
dos = new DataOutputStream(bos);
int len = dis.read();
while(len!=-1){
dos.write(len);
len = dis.read();
System.out.println(len);
}
System.out.println(Thread.currentThread().getName()+"复制图片成功");
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally{
try {
if(dos!=null){
dos.close();
}
if(dis!=null){
dis.close();
}
} catch (Exception e2) {
}
}
}
}
package com.phone.week5.day1;
public class Test3 {
public static void main(String[] args) {
SomeThread some = new SomeThread();
Thread thread1 = new Thread(some);
thread1.start();
try {
for (int i = 0; i < 100; i++) {
if(i==50){
Thread.sleep(5000);
}
System.out.println("555555555555555555555555555555555"+i);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
//some.terimate();
thread1.interrupt();
}
}
class SomeThread implements Runnable {
private boolean flag = true;
public void terimate() {
this.flag = false;
}
public void run() {
System.out.println("....run..........");
/*while (flag) {
System.out.println("...run...");
}*/
try {
Thread.sleep(9000);
} catch (InterruptedException e) {
System.out.println("子线程在睡觉了。");
e.printStackTrace();
}
}
}
package com.phone.week5.day1;
/**
* 4个窗口卖票,一共卖100张
*
*创建线程的第二种方式
*1,首先写一个类实现Runnable接口,重写这个接口的run方法,这个run方法里写的就是每个线程要执行的代码
*2,创建实现Runnable接口类的实例对象
*3.创建多个线程,把这个实现Runnable接口类的实例对象作为线程的参数传递进来
*4.开启线程
*这样的话,可以实现 多个线程操作同一个资源
*注意,实现 Runnable接口的类,它不是一个线程,它只是线程要执行的目标对象
*在开发中,我们经常使用这种方式来实现多线程,因为第一它可以解决单根继承的问题,可以实现多个线程共享同一资源的数据
*
*练习:
*一共有5个苹果,3个小孩来拿,拿完为止
*/
public class Test4 {
public static void main(String[] args) {
/*WD wd= new WD(); //创建一个线程要执行的目标对象
Thread w = new Thread(wd,"一号窗口");
Thread w2 = new Thread(wd,"二号窗口");
Thread w3 = new Thread(wd,"三号窗口");
Thread w4 = new Thread(wd,"四号窗口");
w.start();
w2.start();
w3.start();
w4.start();*/
Apple a = new Apple();
Thread t1 = new Thread(a, "小强");
Thread t2 = new Thread(a, "小明");
Thread t3 = new Thread(a, "小红");
t2.setPriority(Thread.MAX_PRIORITY);
t1.setPriority(Thread.MIN_PRIORITY);
t3.start();
t1.start();
t2.start();
System.out.println(t1.getPriority());
System.out.println(t2.getPriority());
System.out.println(t3.getPriority());
System.out.println(t1.toString());
System.out.println(t2.toString());
System.out.println(t3.toString());
}
}
class Window extends Thread{
public Window(String name){
super(name);
}
private static int ticket = 100; //一百张票
@Override
public void run() {
while(true){
if(ticket>0){
System.out.println(Thread.currentThread().getName()+”剩余”+ticket+”张票”);
ticket–;
}else{
break;
}
}
}
}
class WD implements Runnable{
private int ticket = 100; //一百张票
@Override
public void run() {
while(true){
System.out.println("开始执行RUN方法");
if(ticket>0){
System.out.println(Thread.currentThread().getName()+"剩余"+ticket+"张票");
ticket--;
}else{
break;
}
}
}
}
class Apple implements Runnable{
private int apple = 5;
private int num = 1;
@Override
public void run() {
//每个线程要执行的内容
while(num<=5){
System.out.println(Thread.currentThread().getName()+"拿了第"+num+"个苹果,还剩下:"+(--apple)+"个苹果");
num++;
}
}
}
package com.phone.week5.day1;
/*
* 让线程停止的方法
* 1.如果线程里执行的是一个循环,如果想让线程停止,可以设置一个标识符,在适当的时候,去改变这个标识,这样,就
* 可以让线程停止
*
* 2.如果线程里有调用sleep()方法,想让线程停止,可以调用该线程的interrupt()
*/
public class Test5 {
public static void main(String[] args) {
TT t = new TT();
t.start();
for (int i = 0; i < 10; i++) {
if(i==2){
//t.close();
t.interrupt(); //中断线程
}
System.out.println(i);
}
}
}
class TT extends Thread{
private boolean flag = true;
@Override
public void run() {
/*while(flag){
System.out.println("...run....");
}*/
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
System.out.println("被别人打断了。。。。 ");
e.printStackTrace();
}
}
public void close(){
flag = false;
}
}
package com.phone.week5.day1;
//练习:使用JOIN方法让两个线程之间数据进行传递
//哪个线程调用了join方法,就会让哪个线程先执行,而且是执行完
//yield()方法:意思当前正在执行的线程如果调用了这个方法,表示把CPU的使用权交出去了,但是马上又可以抢,
//把线程的运行状态变成了可运行状态
//sleep(long milins):把当前线程的可运行状态变成阻塞状态,直到睡眠时间到了,它才能进入可运行状态
//setName(String name):设置线程的名字
//getName():获得线程的名字
//setDaemon(true):设置指定线程为守护线程,也叫后台线程
public class Test6 {
public static void main(String[] args) throws InterruptedException {
FF ff = new FF();
ff.setName("守护线程");
ff.setDaemon(true); //表示把这个线程设置为守护线程(也叫后台线程)
ff.start();
for (int i = 0; i < 10; i++) {
System.out.println(Thread.currentThread().getName()+":"+i);
}
/*CC d1 = new CC();
CC d2 = new CC();
d1.setName("AA");
d2.setName("BB");
d1.start();
d2.start();*/
/*DD d = new DD("子线程");
d.start();
//d.join();
d.yield();
System.out.println(d.value);
System.out.println(d.value2);*/
/*for (int i = 0; i <10; i++) {
//让子线程先执行
if(i==5){
DD d = new DD("子线程");
d.start();
try {
d.join();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
System.out.println(Thread.currentThread().getName()+":"+i);
}*/
}
}
class DD extends Thread{
String value;
String value2;
public DD(String name){
super(name);
}
@Override
public void run() {
value="you";
value2 = "him";
/* for (int i = 0; i < 5; i++) {
System.out.println(Thread.currentThread().getName()+":"+i);
}*/
}
}
class CC extends Thread{
@Override
public void run() {
for (int i = 0; i <10; i++) {
System.out.println(Thread.currentThread().getName()+":"+i);
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
class FF extends Thread{
@Override
public void run() {
while(true){
System.out.println(Thread.currentThread().getName()+":---------------------");
}
}
}