java - day018 - 线程续
- 生产者,消费者
- 线程间的通信模型
- 等待和通知
- 在生产者和消费者模型中
- 消费者暂停等待数据
- 生产者产生数据后发出通知
- object 方法
- wait();
- notify(); 通知一个
- notifyAll();通知全部
- 调用 stack.wait();
- 当前线程,在stack 对象上等待
- 调用 stack.notifyAll();
- 在 stack 上发出通知,通知在 stack 对象上等待的线程
- 注意:
- 必须在 synchronized 同步代码快中调用
- 必须在加锁的对象上等待或通知
- synchronized (a) { a.wait(); a.notifyAll(); }
- 为了保证安全, wait()外面总应该是一个循环判断 while
package day1802_生产者消费者; import java.util.Random; public class Producer extends Thread{
private Stack stack; public Producer(Stack stack) {
super();
this.stack = stack;
} @Override
public void run() {
super.run();
while (true) {
char c = (char)('a' + new Random().nextInt());
synchronized (stack) { while (stack.isFull()) {
try {
stack.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} stack.push(c);
System.out.println("压入>>"+c); stack.notifyAll();
} } } }package day1802_生产者消费者; public class Consumer extends Thread{
private Stack stack; public Consumer(Stack stack) {
super();
this.stack = stack;
} @Override
public void run() {
// TODO Auto-generated method stub
super.run(); while (true) {
synchronized (stack) {
while (stack.isEmpty()) {
try {
stack.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} char c = this.stack.pop();
System.out.println("弹出>>"+c); stack.notifyAll();
} }
} }package day1802_生产者消费者; public class Stack { private char[] a = new char[];
private int index; public void push(char c) {
if (isFull()) {
return;
} a[index] = c;
index++;
} public char pop() {
if (isEmpty()) {
return ' ';
}
index--;
return a[index];
} public boolean isEmpty() {
// TODO Auto-generated method stub
return index==;
} public boolean isFull() {
// TODO Auto-generated method stub
return index==;
} }package day1802_生产者消费者; import com.sun.swing.internal.plaf.synth.resources.synth; public class Test1 {
public static void main(String[] args) {
Stack stack = new Stack();
Producer producer = new Producer(stack);
Consumer consumer = new Consumer(stack); producer.start();
consumer.start(); // main 线程 死循环发通知
while (true) {
synchronized (stack) {
stack.notifyAll();
}
}
} }
- 线程监视器模型
- 遇到 synchronized 关键字 ,在加锁的对象会关联一个同步监视器
- 网络通信
- window 终端输入 ipconfig
- mac 终端输入 ifconfig
- ping 192.168.4.xxx, ping 不通, 关闭防火墙
- Socket 网络通信
- socket 网络套接字 (插头)
- 主机之间, 需要能用 IP地址,找到对方
- 在主机上选择一个端口, 来插插头(socket)
- 端口有 0 到 65535 个 端口
- 服务器端
- 被动的等待客户端发起连接
- 在一个端口上启动服务
- 客户端
- 向指定的服务器的 IP地址和端口号 发起连接,建立连接通道
- 连接通道的两端, 都有一个插头
- ServerSocket
- 启动服务
- ServerSocket ss = new ServerSocket(8000);
- 端口必须独占
- 0-1024,是常见服务的默认端口
- 50000之后是,是系统的保留端口来动态分配
- 方法
- accept()
- 暂停,等待客户端发起连接
- 建立与客户端的链接通道,并返回通道的服务器插头对象
- close()
- 停止服务, 释放端口
- 网络通信的阻塞操作
- ss.accept();// 阻塞暂停等待
- in.read(); // 阻塞,接收数据,对方不发送,死等
- 服务器端的线程模型
java - day018 - 线程续的更多相关文章
- Java调度线程池ScheduleExecutorService(续)
链接 Java线程池详解(一) Java线程池详解(二) Java调度线程池ScheduleExecutorService 上面列出了最近写的关于java线程池ScheduleExecutorServ ...
- java之线程
java之线程 一:线程: 线程是什么呢?线程,有时被称为轻量级进程是程序执行流的最小单元.一个标准的线程由线程ID,当前指令指针(PC),寄存器集合和堆栈组成.另外,线程是进程中的一个实体,是被系统 ...
- Java 使用线程方式Thread和Runnable,以及Thread与Runnable的区别
一. java中实现线程的方式有Thread和Runnable Thread: public class Thread1 extends Thread{ @Override public void r ...
- Java的线程安全
线程安全 我们这里讨论的线程安全,就限定于多个线程之间存在共享数据访问这个前提,因为如果一段代码根本不会与其他线程共享数据,那么从线程安全的角度来看,程序是串行执行还是多线程执行对它来说是完全没有区别 ...
- 深入理解Java之线程池
原作者:海子 出处:http://www.cnblogs.com/dolphin0520/ 本文归作者海子和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则 ...
- java中线程分两种,守护线程和用户线程。
java中线程分为两种类型:用户线程和守护线程. 通过Thread.setDaemon(false)设置为用户线程: 通过Thread.setDaemon(true)设置为守护线程. 如果不设置次属性 ...
- java 多线程—— 线程让步
java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...
- java 多线程—— 线程等待与唤醒
java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...
- Java的线程模型
并发不一定要依赖多线程(如PHP中很常见的多进程并发),但是在Java里面谈论并发,大多数都与线程脱不开关系. 线程是比进程更轻量级的调度执行单位,线程的引入,可以把一个进程的资源分配和执行调度分开, ...
随机推荐
- Redis的特性及运用
Redis特性 一个产品的使用场景肯定是需要根据产品的特性,先列举一下Redis的特点: 读写性能优异 持久化 数据类型丰富 单线程 数据自动过期 发布订阅 分布式 这里我们通过几个场景,不同维度说下 ...
- 爬虫存储介质之CSV文件存储
本文章来自度娘 CSV文件存储 CSV,全称为Comma-Separated Values,中文可以叫做逗号分隔值或字符分隔值,其文件以纯文本形式 存储表格数据.该文件是一个字符序列,可以由任意数目的 ...
- nodejs ffi 调用dll
安装依赖 npm install --global --production windows-build-tools(在管理员权限打开的命令行中执行) npm install -g node-gyp ...
- k8s nfs
1 yum install -y nfs-utils-* 2 mkdir /home/data 3 vim /etc/exports /home/data 10.0.0.0/24(rw,async,n ...
- Linux将.deb以绿色免安装的方式“安装”
1.如果是xxx.deb文件,一般网上都是教你dkpg -i xxx.deb,但是这种方式类似windows里的安装,可能会在很多地方生成一些“垃圾”数据[比如不需要在dpkg安装应用信息文件里写入此 ...
- 【转帖】为什么redis 是单线程的?
为什么redis 是单线程的? https://cloud.tencent.com/developer/article/1120615 云服务器企业新用户优先购,享双11同等价格 立即抢购 以前一直有 ...
- PAT(B) 1028 人口普查(C)字符串
题目链接:1028 人口普查 (20 point(s)) 题目描述 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是 ...
- 微软商店一直安装不上Intel Media SDK DFP
具体表现为一直安装失败,但是下载进度条一直在,无法去除. 此方法来自 https://answers.microsoft.com/en-us/windows/forum/all/error-code- ...
- C++11(及现代C++风格)和快速迭代式开发
过去的一年我在微软亚洲研究院做输入法,我们的产品叫“英库拼音输入法” (下载Beta版),如果你用过“英库词典”(现已更名为必应词典),应该知道“英库”这个名字(实际上我们的核心开发团队也有很大一部分 ...
- SpringBoot学习(五)—— springboot快速整合Druid
Druid连接池 简介 由阿里巴巴开源的druid连接池是目前综合实力最突出的数据库连接池,而且还提供了监控日志功能,能够分析SQL执行情况. 引入druid连接池 pom.xml中加入 <de ...