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

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

SpringBoot项目是如何启动

启动步骤 概念 运行main方法,初始化SpringApplication 从spring.factories读取listener ApplicationContentInitializer运行run方法读取环境变量,配置信息创建SpringApplication上下文预初始化上下文,将启动类作为配置类进行读取调用 refresh 加载 IOC容器,加载所有的自动配置类,创建容器在这个过程

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免

2. 下载rknn-toolkit2项目

官网链接: https://github.com/airockchip/rknn-toolkit2 安装好git:[[1. Git的安装]] 下载项目: git clone https://github.com/airockchip/rknn-toolkit2.git 或者直接去github下载压缩文件,解压即可。

9.8javaweb项目总结

1.主界面用户信息显示 登录成功后,将用户信息存储在记录在 localStorage中,然后进入界面之前通过js来渲染主界面 存储用户信息 将用户信息渲染在主界面上,并且头像设置跳转,到个人资料界面 这里数据库中还没有设置相关信息 2.模糊查找 检测输入框是否有变更,有的话调用方法,进行查找 发送检测请求,然后接收的时候设置最多显示四个类似的搜索结果

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令 在日常的工作中由于各种原因,会出现这样一种情况,某些项目并没有打包至mvnrepository。如果采用原始直接打包放到lib目录的方式进行处理,便对项目的管理带来一些不必要的麻烦。例如版本升级后需要重新打包并,替换原有jar包等等一些额外的工作量和麻烦。为了避免这些不必要的麻烦,通常我们

html css jquery选项卡 代码练习小项目

在学习 html 和 css jquery 结合使用的时候 做好是能尝试做一些简单的小功能,来提高自己的 逻辑能力,熟悉代码的编写语法 下面分享一段代码 使用html css jquery选项卡 代码练习 <div class="box"><dl class="tab"><dd class="active">手机</dd><dd>家电</dd><dd>服装</dd><dd>数码</dd><dd