开课吧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

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

MyCat分库分表的项目实践

《MyCat分库分表的项目实践》分库分表解决大数据量和高并发性能瓶颈,MyCat作为中间件支持分片、读写分离与事务处理,本文就来介绍一下MyCat分库分表的实践,感兴趣的可以了解一下... 目录一、为什么要分库分表?二、分库分表的常见方案三、MyCat简介四、MyCat分库分表深度解析1. 架构原理2. 分

linux查找java项目日志查找报错信息方式

《linux查找java项目日志查找报错信息方式》日志查找定位步骤:进入项目,用tail-f实时跟踪日志,tail-n1000查看末尾1000行,grep搜索关键词或时间,vim内精准查找并高亮定位,... 目录日志查找定位在当前文件里找到报错消息总结日志查找定位1.cd 进入项目2.正常日志 和错误日

在.NET项目中嵌入Python代码的实践指南

《在.NET项目中嵌入Python代码的实践指南》在现代开发中,.NET与Python的协作需求日益增长,从机器学习模型集成到科学计算,从脚本自动化到数据分析,然而,传统的解决方案(如HTTPAPI或... 目录一、CSnakes vs python.NET:为何选择 CSnakes?二、环境准备:从 Py

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca