开课吧T31项目第17天

2024-03-01 21:10
文章标签 项目 17 开课 t31

本文主要是介绍开课吧T31项目第17天,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

T31项目第17天

  • 集合和并发编程
    • 1.UML图解
      • 1.1 功能树
      • 1.2用例图
      • 1.3 部署图
    • 2.集合
      • 2.1 java集合框架图
      • 2.2 数据结构和时间复杂度
      • 2.3常用算法复杂度
      • 2.4HashMap的基本概念
      • 2.5Collection的基本概念
      • 2.6 ArrayList 中sublist
    • 3.并发编程
      • 3.1并行和并发的区别
      • 3.2线程安全
      • 3.2锁
      • 3.3AQS
      • 3.4 lock与 AQS和AOS之间的关系
      • 3.5 AQS代码分析
      • 3.6线程和线程池的奥秘

今天是孤尽班学习的第17天,今天跟着孤尽老师学习 UML图解、集合、并发编程,感谢老师们的辛勤付出,我会继续努力,加油。

集合和并发编程

1.UML图解

1.1 功能树

在这里插入图片描述

关注每个大的模块所具备的功能,每个功能所具备的功能点
例如:用户模块 包含 用户注册,用户信息修改,用户注销,用户查询等功能

1.2用例图

关注系统中有哪些用户
例如服务门店管理系统的角色有: 系统用户(店员,店长,系统管理员,总经理),用户(会员)
在这里插入图片描述

1.3 部署图

部署图关注 部署元素和部署元素之间的联系
部署元素:微服务,数据库
部署关联元素:注册中心,消息中间件
在这里插入图片描述

2.集合

2.1 java集合框架图

接口集合包含接口(collection,map,list,set),抽象类(abtrast**)、并发包中的类,早期线程安全的类
在这里插入图片描述

2.2 数据结构和时间复杂度

数据结构:按照逻辑意义的数据组织方式及其相应的处理方式
数据组织方式:线性结构、图结构、图结构、哈希结构
在这里插入图片描述

2.3常用算法复杂度

在这里插入图片描述
hash类集合的三个存储概念:
table:存储所有节点数据的数组
slot:哈希槽,就是 table[i]位置
bucket(桶):哈希桶,table【1】这个位置的所有的表或数的集合

在这里插入图片描述

2.4HashMap的基本概念

第一句常量定义:hashMap中每个桶容量数据超过等于8个时,会从链表转为红黑树
第三局常量定义:hashMap中初始数容量为64,大于等于64才会向树转化
在这里插入图片描述
hashMap内存分配机制:
在这里插入图片描述
分配16个存储空间,为什么会分配16个存储空间,我们分析一下
1.cap值为13,cap值带入numberLeadingZeros()的方法中
2.因为13大于0,则进行以下的计算
补充:<<符号是二进制数左移运算,如果为正数,每进一位,后面一位补0,如果为负数,每进一位,则后面一位补1
3.以下条件转换为
if(i>2^16)
if(i>2^8)
if(i>2^4)
if(i>2^2)
4.将13带入条件中,13只符合最后一条计算公式,则执行最后一条的运算
n-=2 ,因为初始n为31,则 n计算之后值为 29
5. 这个>>>符号是二进制数无符号右移的运算,高位向低位每移动一位,高位全部补0,等到新的二进制数
6.i>>>2, 12的二进制数为1100B,向右移动2位,得到的值为11B,换算为十进制为3
7.返回值 return n-(i>>>1),i向右移动一位为1B,换算为十进制为1,则返回值为 29-1=28
8.最后得到 需要将 -1向 无符号移动28位,最后得到 移动后的数为 1111B,换算为十进制为15
9.因为 15小于MaxImumi的值64,则进行后面的计算 15+1,则得到最后的容器的容量为 16

在这里插入图片描述
hash中落槽计算
n为16,n>>>16,无符号向右一定16位,为0B,再与key.hashcode进行异或运算
计算进行16位数的右移动之后再与key.hashcode()值进项异或的目的是为了避免高位和低位的值都是重复有规律数字例如连续16个1 或者16,避免值重复
在这里插入图片描述
落槽时值判断
得到槽位之后,会进行判断 落槽位置是否有值,如果无值则直径存放至,如果存在冲突,最后还是会复制成功
在这里插入图片描述
判断值是否需要扩容
当HashMap的容量小于64时,不管节点是否冲突,一律先扩容
在这里插入图片描述

2.5Collection的基本概念

Collection.toMap()的异常问题如果值重复时,会出现Dupline()异常,当出现异常时,需要人为处理
在这里插入图片描述
人为处理 Collection.toMap(),也会出现NPE的问题
在这里插入图片描述

原因是:merger()的方法中也有判断值不为空的问题,如果值为空会有NPE错误
在这里插入图片描述

2.6 ArrayList 中sublist

sublist()的返回值是 ArrayList的内部类SubList,不会转换为ArrayList
在这里插入图片描述

sublist()场合注意事项
在这里插入图片描述

3.并发编程

3.1并行和并发的区别

并行:同时处理多任务的能力
并发:某个时间段,多任务交替处理
在在系统环境中,CPU不同时刻交替执行不同的犯法,是并发
CPU同时执行不同的方法是并行

3.2线程安全

计算机中每个线程轮流占用CPU资源进行计算,可能出现一个线程没有执行完不得中断情况,会导致之前的操作信息被其他线程篡改,导致信息和实际结果不一致,导致线程不安全的情况
在这里插入图片描述

保证线程安全可以从以下几点考虑:
1.数据单线程可见
2.只读对象
3.线程安全性
4.同步与锁机制

3.2锁

对于多线程才有锁的应用
锁的出现是为了保证在资源竞争的情况下保证安全高效
java中实现锁的方式:并发包中的锁类(例如 lock);利用同步代理块(syconizad)

3.3AQS

state(int) 是AQS中核心资源,线程争夺是争夺state 资源
在这里插入图片描述

3.4 lock与 AQS和AOS之间的关系

AOS继承了AQS,在所有的的锁中都会体现,AOS几乎融入到所有的锁中
在这里插入图片描述

3.5 AQS代码分析

Sync Queue 同步队列
Condition Queue 等待队列

在这里插入图片描述

AQS通过CLH机制来管理Node节点的先后顺序,通过 Ndde对象的Next 和 Pre实现 双向队列
在这里插入图片描述

3.6线程和线程池的奥秘

线程的状态
线程拥有自己的操作栈、程序计数器、局部变量表等资源,它与同一个进程内的其他进程共享该资源
新建、就绪、运行、阻塞、灭亡
在这里插入图片描述

线程池的状态
运行、停止、阻塞、关闭,中断
在这里插入图片描述
线程池的作用:
1.利用线程池管理并复用线程、控制最大并发数
2.增加对线程的管理,快速排查问题
.3.实现任务与线程队列缓存策略和拒绝机制
4.实现某些与时间相关的功能,如:定时执行、周期执行
5.隔离线程环境

线程池的类图
在这里插入图片描述
线程池的构造方法
在这里插入图片描述

这篇关于开课吧T31项目第17天的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

SpringBoot项目启动报错"找不到或无法加载主类"的解决方法

《SpringBoot项目启动报错找不到或无法加载主类的解决方法》在使用IntelliJIDEA开发基于SpringBoot框架的Java程序时,可能会出现找不到或无法加载主类com.example.... 目录一、问题描述二、排查过程三、解决方案一、问题描述在使用 IntelliJ IDEA 开发基于

SpringBoot项目使用MDC给日志增加唯一标识的实现步骤

《SpringBoot项目使用MDC给日志增加唯一标识的实现步骤》本文介绍了如何在SpringBoot项目中使用MDC(MappedDiagnosticContext)为日志增加唯一标识,以便于日... 目录【Java】SpringBoot项目使用MDC给日志增加唯一标识,方便日志追踪1.日志效果2.实现步

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法

《SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法》本文主要介绍了SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录方法1:更改IDE配置方法2:在Eclipse中清理项目方法3:使用Maven命令行在开发Sprin

Nginx实现高并发的项目实践

《Nginx实现高并发的项目实践》本文主要介绍了Nginx实现高并发的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用最新稳定版本的Nginx合理配置工作进程(workers)配置工作进程连接数(worker_co

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx

SpringBoot项目注入 traceId 追踪整个请求的日志链路(过程详解)

《SpringBoot项目注入traceId追踪整个请求的日志链路(过程详解)》本文介绍了如何在单体SpringBoot项目中通过手动实现过滤器或拦截器来注入traceId,以追踪整个请求的日志链... SpringBoot项目注入 traceId 来追踪整个请求的日志链路,有了 traceId, 我们在排