很多初学者不明白Java多线程的概念java监控线程状态,无限互联Java培训专家认为先从掌握基本的线程概念开始java监控线程状态,才能更加深刻的认知多线程java监控线程状态,通俗的讲就是多个并行运行的while循环java监控线程状态,可以并发做多个事情,那么多个线程在实际使用过程中有可能会操作同一个数据块,那么问题多线程注意的问题就出现java监控线程状态了。
Java培训学习:Java线程学习
先来了解线程基本概念以及简单代码实现,更多Java相关学习,欢迎点击https://java.wuxianedu.com/
Java线程学习经典例子
Java线程学习最经典的例子,主要用到Thread相关知识如下:
-线程的start与run
-线程的休眠(sleep)
-数据对象加锁(synchronized)
-数据对象的等待与释放(wait and notify)
程序实现:
-ObjectData数据类对象,通过synchronized关键字实现加锁,在线程读写者中使用。
-ConsumerThread消费者线程,读取数据对象中count值之后,通知生产者线程
-ProductThread生产者线程,对数据对象中count值操作,每次加1,然后通知消费者线程
类结构图如下:
Java培训学习:Java线程学习
代码实现
消费者-读线程
package com.gloomyfish.jse.thirdteen;
public class ConsumerThread extends Thread {
private ObjectData data;
public ConsumerThread(ObjectData data) {
this.data = data;
}
@Override
public void run() {
while(true) {
try {
synchronized (data) {
data.wait();
data.read();
data.notify();
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
写线程-生产者线程
package com.gloomyfish.jse.thirdteen;
public class ProductThread extends Thread {
private ObjectData data;
public ProductThread(ObjectData data) {
this.data = data;
}
@Override
public void run() {
while (true) {
try {
synchronized (data) {
data.write();
Thread.sleep(3000);
data.notify();
data.wait();
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
数据对象类
package com.gloomyfish.jse.thirdteen;
public class ObjectData {
private int count;
public ObjectData() {
count = 0;
}
public void read() {
System.out.println("read count : " + count);
System.out.println();
}
public void write() {
count++;
System.out.println("write count : " + count);
}
}
测试代码:
public static void main(String[] args) {
ObjectData data = new ObjectData();
ConsumerThread ct = new ConsumerThread(data);
ProductThread pt = new ProductThread(data);
ct.start();
pt.start();
}
总结:
示例程序代码完成了线程之间如何通过wait与notify实现数据的读写同步控制。演示了Java的同步关键字synchronized的用法与线程的用法。
Java自学能学会吗?学Java能拿多少薪资?学Java好找工作吗?企业需要什么样的Java工程师?
学Java当然要到选择靠谱的Java培训机构,选择人多的,自然是好培训,学习Java,就找无限互联Java培训中心!
关键词标签;Java培训,Java课程,Java学习
原文链接:https://java.wuxianedu.com/a/news/2016/1214/245.html
发表评论
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。