android开发巩固java基础 notify wait的妙用javaandroid测试以及翻出我之前2015年的有道云笔记供大家参考...

本文主要是介绍android开发巩固java基础 notify wait的妙用javaandroid测试以及翻出我之前2015年的有道云笔记供大家参考...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

经常玩 测试类的都应该知道,android测试测试子线程的时候往往直接结束了,并没有看到日志打印,难道真的没法测试了吗?

其实不然,java的notifywait就可以派上用场啦!
在android test快结束的时候 synchronized锁进行等待即可.

有时候java基础还是很重要的啦,当然咯,很久没玩java 线程同步,可能全还给老师也是可以理解的.

package cn.qssq666.videotest;/*** Created by qssq on 2018/4/20 qssq666@foxmail.com*/
public class WaitTest {@org.junit.Testpublic void waitAndNotify() {final Object lock = new Object();new Thread(new Runnable() {int count = 0;@Overridepublic void run() {while (count < 10) {try {Thread.sleep(1000);System.out.println("current :" + count);} catch (InterruptedException e) {e.printStackTrace();}count++;}System.out.println("我是子线程:" + Thread.currentThread().getName());System.out.println("调用notify start");synchronized (lock) {lock.notify();//必须同步锁包裹才能进行调用 Exception in thread "Thread-0" java.lang.IllegalMonitorStateException}System.out.println("调用notify end");}}).start();System.out.println("即将进入线程等待");synchronized (lock) {try {lock.wait();
//                lock.wait(1000555);} catch (InterruptedException e) {e.printStackTrace();}System.out.println("收到notify,退出等待");}}
}

那么打印的结果打印也应该可以猜到了

即将进入线程等待
current :0
current :1
current :2
current :3
current :4
current :5
current :6
current :7
current :8
current :9
我是子线程:Thread-0
调用notify start
调用notify end
收到notify,退出等待

随便记录一下要添加的依赖

dependencies {androidTestCompile 'com.android.support.test:runner:0.4.1'//android测试androidTestImplementation 'com.android.support.test:rules:0.4.1'androidTestImplementation 'com.android.support.test.espresso:espresso-core:2.2.1'//android测试compile fileTree(include: ['*.jar'], dir: 'libs')testImplementation 'junit:junit:4.12' //java测试
}

最后我从有道云中找到了我2015年的笔记说实话我现在看的云里雾里,到底是那时候太菜,还是现在太菜忘记了所有???

线程和进程相关知识点

进程 就是运行的程序
线程 就是 进程 总的一个执行路径
多线程:一个进程中 有多个进行,多个执行路径可以执行多个任务代码
多线程的好处:
解决1个进程中可以执行多个任务
提高了资源利用率
多线的的坏处:
增加了cpu的负担,
降低了进程中线程的执行概率
容易引发线程安全问题
用同步锁 容易出现死锁现象
线程的创建方式有2中

1 继承Thread 重写run方法

new自身 继承了父类Thread的start() 所以直接new自身类().start()就可以启动线程

2 实现Runnable 实现run方法

把Runnable实现类传递给Thread类
new Thread(new 实现Runnable类()).start();
JAVA同步机制:

同步代码块

格式:

synchronized(锁对象){}
同步代码块注意事项

锁对象可以是任意对象,因为有隐式变量 可当锁

锁对象必须多个线程共享一个对象,要保证唯一

一个线程调用sleep方法 不会释放锁对象

如果当前代码没有存在线程安全问题,千万不要使用同步机制

否则会降低执行效率

同步函数

1、非静态函数的锁对象是this对象,静态函数锁对象是当前函数所属类的class对象 this.getClass
第二种: 直接填写指定文件 如 Person.Class
第三种:对象.getClass
另外获取自身对象 直接 this就可以死锁现象
线程和线程之间出现了互相等待对象资源的情况

代码笔记
package sernirolock1;//import java.util.concurrent.locks.Condition;import java.util.concurrent.locks.Lock;import java.util.concurrent.locks.ReentrantLock;public class Demo {/*** @param args* 高级   不同线程池 实现 线程通信* 本例使用lock 显式锁对象和condition 监视器实现了不同线程池 多线程通信* 而用synchronized是无法实现的。*/public static void main(String[] args) {Resource r = new Resource();Lock l = new ReentrantLock();Condition cCondition = l.newCondition();Condition pCondition = l.newCondition();new Producter("情迁的老婆", r, l, cCondition,pCondition).start();new Customer("情迁", r, l, cCondition,pCondition).start();}}class Resource {public String name;public int price;public boolean flag;// 真为已生产public Lock lock;public Condition condition;}class Producter extends Thread {Resource resource;Lock lock;Condition cCondition;Condition pCondition;public Producter(Resource resource, Lock lock, Condition cCondition,Condition pCondition) {this.resource = resource;this.lock = lock;this.cCondition = cCondition;this.pCondition = pCondition;}/**** @param name* @param resource*            被共享资源* @param lock*            锁对象*/public Producter(String name, Resource resource, Lock lock,Condition cCondition,Condition pCondition) {super(name);this.resource = resource;this.lock = lock;this.cCondition = cCondition;this.pCondition = pCondition;}@Overridepublic void run() {int i = 0;while (true) {lock.lock();if (!resource.flag) {if (i % 2 == 0) {resource.name = "自行车";resource.price = 300;} else {resource.name = "摩托车";resource.price = 1000;}System.out.println(this.getName() + "生产了价值" + resource.price+ "元的" + resource.name);resource.flag = true;cCondition.signal();//我是生产发送信号给监视器->消费者线程i++;} else {try {pCondition.await();//我是生产线程,没人消费我就暂时不生产} catch (InterruptedException e) {//e.printStackTrace();}}lock.unlock();}}}class Customer extends Thread {Resource resource;Lock lock;Condition cCondition;Condition pCondition;public Customer(Resource resource, Lock lock, Condition cCondition,Condition pCondition) {this.resource = resource;this.lock = lock;this.cCondition = cCondition;this.pCondition = pCondition;}public Customer(String name, Resource resource, Lock lock,Condition cCondition,Condition pCondition) {super(name);this.resource = resource;this.lock = lock;this.cCondition = cCondition;this.pCondition = pCondition;}@Overridepublic void run() {while (true) {lock.lock();if (resource.flag) {System.out.println(this.getName() + "消费了价值"+ resource.price + "元的" + resource.name);resource.flag = false;pCondition.signal();//我是消费发送信号给监视器->生产者线程} else {try {cCondition.await();//我是消费者线程,我已经消费完毕,我睡了哈} catch (InterruptedException e) {//e.printStackTrace();}}lock.unlock();}}}

这篇关于android开发巩固java基础 notify wait的妙用javaandroid测试以及翻出我之前2015年的有道云笔记供大家参考...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/959163

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D