Java基础07--多线程-网络编程-Java高级

一、多线程

1.认识多线程

①线程

②多线程

2.创建线程方式

①方式一:继承Thread类

1.让子类继承Thread线程类
2.重写run方法,就是这个线程执行会执行的操作。
3.创建继承Thread的子类对象就代表一个线程
4.启动线程:.start()-自动执行run方法

注意:main是一条默认的主线程,这个子类对象是子线程

对于第一条,相当于把子线程就当一个对象执行它的方法
对于第二条,如果放在前面,执行不到start方法就启动不了子线程

②方式二:实现Runnable接口

1.定义一个任务类,实现Runnable接口
2.重写Runnable的run方法
3.创建任务对象
4.把任务对象交给一个线程对象

其匿名内部类写法:

③方式二:利用Callable接口、FutureTask类

前面两个方式都不能返回值run方式是void

实现Callable,要执行的操作

Callable是泛型接口,要返回什么类型数据就在<>填

3.Thread线程类的常用方法

注意:currentThread方法是在哪个线程里执行就会拿到哪个线程对象
所以拿到名字可以判断是哪个线程在执行操作

设置名字:在使用构造器创建线程对象设置名字就需要在创建的那个线程类构造器使用Thread的构造器

sleep、join方法:

如果这样就会让t1,t2,t3线程顺序执行完毕

4.线程安全

模拟线程安全问题

第二个判断的时候,第一个取钱的操作还没执行,就还可以取钱,出现线程安全

5.线程同步

①认识线程同步:

②方式一:同步代码块

双引号代表的对象只有一份,就限制了所有线程访问此核心判断代码都只能一个接着一个进行,这样如果是另一个账户对象要取钱就不能操作了

普通成员方法建议使用this

静态方法,调用时使用类名,所以建议使用类名作为锁

③方式二:同步方法

就是在方法前加修饰词synchronized

性能比同步代码块差,因为,同步代码块可以先执行一些操作,但是现在可以忽略不记,同步方法可读性更好

④方式三:Lock锁

每个类对象都应该有个自己的锁对象,所以定义实例变量Lock。

final代表了lk不可二次赋值

加锁解锁放在try-finally中的finally区中,这样就保证了不会出现中间出现问题不会进行解锁的操作

6.线程通信-了解

7.线程池

①认识线程池

若线程池中的数量固定,线程占满,任务会排队,待线程执行完之前操作会继续执行后续任务

②创建线程池

参数很重要

临时线程数量等于最大线程数量减去核心线程数量,核心线程会一直存在,线程工厂负责去创建临时线程

最大存活时间后跟了TimeUnit.SECONDS代表是秒,任务队列可以是:new LinkedBlockingQueue<>,但更多采用基于数组的new ArrayBlockingQueue<>(),线程工厂这是个创建默认线程工厂的方式,任务拒绝策略是使用了ThreadPoolExecutor的内部类,当最大线程数量都在工作,任务队列也满了就会抛异常给任务队列。      

③线程池处理Runnable任务

临时线程会在核心线程都在工作,任务队列占满的情况下创建,超过临时创建的数量就会抛异常

任务拒绝策略

④线程池处理Collable任务

⑤Executors工具类实现线程池

核心线程数量配置选择:

注意:在大型并发系统环境中不使用工具类去创建线程池,因为任务队列是无限的,太多会瘫痪

8.并发和并行

①认识进程

CPU同一时间会执行多个线程,并行,CPU这多个线程不断切换,切换很快,导致看上去就是同时进行,并发

9.线程的生命周期

sleep方法不会释放锁,wait会把锁释放

10.悲观锁与乐观锁

悲观锁:一上来就加锁,没有安全感。每次只能一个线程进入访问完毕后,再解锁。
/乐观锁:一开始不上锁,认为是没有问题的,大家一起跑,等要出现线程安全问题的时候才开始控制。线程安全,性能较好。

CAS整数修改的乐观锁:

使用这种锁它会拿到共享资源对象的地址,然后通过地址得到此时需要修改的值的大小,拿期望修改的值在此处就是加一,与那个值进行比较如果不一样,就返回继续拿最新的值与修改的操作加一,直到此时要修改的值和期望值相同,再返回此时要修改的值是多少去加一。
就是判断此时要修改的值是否在我要修改的时被别人已经修改

11.线程应用

二、网络编程

CS\BS都依赖于网络编程

1.网络通信的三要素

IP地址就是设备在网络中的身份证,端口就是应用程序在设备中的身份证

①IP地址

IP域名,就是代表IP地址

IP常用命令在cmd输入

Java中代表IP地址的类:

这里的timeout代表这个时间内是否能联通

②端口号

③协议

我们要关注从应用层到传输层之间的协议

对于TCP协议:
三次握手建立可靠连接

服务器端收到客户端发出的连接请求,确保了客户端可以发消息;客户端收到服务器端返回的响应,确保了服务器端可以收到消息并且可以发消息;而服务器端再次收到客户端发出的确认信息,保证了客户端可以收到消息。
这样就确保了客户端和服务器端都可以收发消息,保证了可靠连接。

四次挥手确保断开连接

2.UDP通信

①入门

客户端的创建:

服务器端对象

服务端先启动,启动后会在receive方法这等待,如果有客户端发送消息才会继续往下
服务器端还可以拿到地址和端口

②多发多收

客户端如何修改

服务端如何改

3.TCP通信

①入门

服务端启动后在accept处等待,与客户端连接后,会在使用socket通信的字节输入流的时候停止等待。

②多发多收

③支持与多个客户端通信

服务器端读数据线程类:

主线程接受客户端:

④端口转发-群聊

服务器端主线程添加集合记录scoket

子线程发送给其他在线客户端方法:

子线程重写run方法,退出时应删除集合元素

客户端若想收消息,得有个子线程负责:

收消息线程类:

⑤BS架构

之前都是CS架构客户端-服务器端

BS架构,浏览器-服务器端

主线程接受浏览器连接:

子线程类:

浏览器是短连接响应后就需要关闭,由于得遵循HTTP协议格式

所以服务器端应该改造成:

太多人访问容易发生并发
使用线程池优化

其实可以不改这个类因为Thread类是实现Runnable的

三、Java高级

1.单元测试

Junit单元测试框架

业务方法:

Junit单元测试框架,断言机制通过

注解:

如果每个方法需要一个独立的通信管道就需要在Before和After中建立和释放资源

测试方法共用同一个通信管道,就在BeforeClass和AfterClass中建立和释放资源

2.反射

①认识反射

②获取类

③获取类的构造器


记记代码风格就行,后续有用

④获取类的成员变量

⑤获取了类的成员方法

⑥反射的作用、应用场景

反射做通用框架

3.注解

①认识注解

如果不止一个属性,但是其他都有默认值则也可以不写

②元注解

③注解的解析

④应用场景



5.动态代理

①创建代理

创建的接口表明了BigStar类要代理的方法,并且BigStar类应该实现这个接口。
代理:

②实际代理应用

统计耗时是相同代码且与业务无关
代理:

用户类

主程序调用:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/611210.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Qlik Sense : Crosstable在数据加载脚本中使用交叉表

什么是Crosstable&#xff1f; 交叉表是常见的表格类型&#xff0c;特点是在两个标题数据正交列表之间显示值矩阵。如果要将数据关联到其他数据表格&#xff0c;交叉表通常不是最佳数据格式。 本主题介绍了如何逆透视交叉表&#xff0c;即&#xff0c;在数据加载脚本中使用 L…

C++11的更新介绍(初始化、声明、右值引用)

&#x1fa90;&#x1fa90;&#x1fa90;欢迎来到程序员餐厅&#x1f4ab;&#x1f4ab;&#x1f4ab; 主厨&#xff1a;邪王真眼 主厨的主页&#xff1a;Chef‘s blog 所属专栏&#xff1a;c大冒险 总有光环在陨落&#xff0c;总有新星在闪烁 C11小故事&#xff1a; 19…

【MCU开发规范】:MCU的性能测试

MCU的性能测试 前序性能评判方法MIPSCoreMark EEMBC其他参考 前序 我们平时做MCU开发时&#xff0c;前期硬件选型&#xff08;选那颗MCU&#xff09;基本由硬件工程师和架构决定&#xff0c;到软件开发时只是被动的开发一些具体功能&#xff0c;因此很少参与MCU的选型。 大部分…

windows环境下实现ffmpeg本地视频进行rtsp推流

摘要&#xff1a;有时候服务端&#xff08;如linux&#xff09;或者边缘端&#xff08;jetson盒子&#xff09;需要接受摄像头的视频流输入&#xff0c;而摄像头的输入视频流一般为rtsp&#xff0c;测试时需要搭建摄像头环境&#xff0c;很不方便&#xff0c;因此需要对本地视频…

docker pull镜像的时候指定arm平台

指定arm平台 x86平台下载arm平台的镜像包 以mysql镜像为例 docker pull --platform linux/arm64 mysqldocker images查看镜像信息 要查看Docker镜像的信息&#xff0c;可以使用docker inspect命令。这个命令会返回镜像的详细信息&#xff0c;包括其元数据和配置。 docker i…

CDHD高创驱动器恢复出厂设置的具体方法演示

CDHD高创驱动器恢复出厂设置的具体方法演示 首先,下载并安装高创驱动器的调试软件,有需要的可以从以下链接中获取:高创CDHD伺服调试软件ServoStudio安装包-V2.38.6.30 安装完成后,打开软件,如下图所示, 如下图所示,在左侧找到配置—通信,点击连接, 如下图所示,正常情…

MySQL进阶一

目录 1.使用环境 2.条件判断 2.1.case when 2.2.if 3.窗口函数 3.1.排序函数 3.2.聚合函数 ​​​​​​​3.3.partiton by ​​​​​​​3.4.order by 4.待续 1.使用环境 数据库&#xff1a;MySQL 8.0.30 客户端&#xff1a;Navicat 15.0.12 2.条件判断 2.1.ca…

Unity MySql安装部署与Unity连接 下篇

一、前言 上篇讲到了如何安装与部署本地MySql&#xff1b;本篇主要讲Unity与MySql连接、创建表、删除表&#xff0c;然后就是对表中数据的增、删、改、查等操作。再讲这些之前会说一些安装MySql碰到的一些问题和Unity连接的问题。 当把本地MySql部署好之后&#xff0c;我们可能…

C++ vector内存分配及正确释放

C vector内存分配及正确释放_vector 释放-CSDN博客 内存分配 #include <iostream> #include <vector> using namespace std;int main(){ vector<int> vec(10); cout << "vec.size: "<< vec.size() <<endl; cout << &quo…

spring.rabbitmq.listener.simple.default-requeue-rejected = false 和放入死信队列的区别

目录 一、场景 二、使用 spring.rabbitmq.listener.simple.default-requeue-rejected false 2.1 特点 三、 放入死信队列 四、两种区别 一、场景 当我们使用RabbitMq的时候&#xff0c;我们如果业务中有异常&#xff0c;很有可能造成死循环&#xff0c;因为 在RabbitMQ和…

OJ刷题日记:1、双指针(1)

目录 1、283.移动零 2、1089.复写零 3、202.快乐数 1、283.移动零 题目&#xff1a; 给定一个数组 nums&#xff0c;编写一个函数将所有 0 移动到数组的末尾&#xff0c;同时保持非零元素的相对顺序。 请注意 &#xff0c;必须在不复制数组的情况下原地对数组进行操作。 …

mysql重启失败

服务器重启了一下&#xff0c;然后启动后发现mysql自动启动没有生效&#xff0c;于是手动通过systemctl启动mysqld&#xff0c;然后就报错:Starting MySQL...........The server quit without updating P[FAILED](/data/mysql/iz2zebvmy1qv3fao9c5riuz.pid). 根据配置my.cnf文…