秋招打卡016(0827)

文章目录

  • 前言
  • 一、今天学习了什么?
  • 二、关于问题的答案
    • 1.牛客网面经
    • 2.美团后端一面
    • 3.动态规划
  • 总结


前言

提示:这里为每天自己的学习内容心情总结;

Learn By Doing,Now or Never,Writing is organized thinking.

先多,后少。


提示:以下是本篇文章正文内容

一、今天学习了什么?

  • 牛客网的面经;
  • 代码随想录的题目;

二、关于问题的答案

1.牛客网面经

阿里控股集团Java一面(51min)

Q:介绍一下HTTPS的三个具体步骤?

我的理解是应该是讲 HTTPS 的三次握手:

第一步:数字证书认证:

  • 客户端向服务端发送 HTTPS 请求,等待服务器的确认;
  • 服务器将 公钥数字证书 的形式发送给客户端,保证公钥不被篡改和可信任
  • 服务端存储了 crt公钥 和 crt私钥;
  • 客户端验证证书的有效性;

第二步:获取对称密钥:

  • 客户端用随机数和hash 签名生成一串对称的密钥,使用服务端的公钥对密钥加密
  • 客户端发送密钥给客户端;
  • 服务端使用私钥解密,获得对称密钥;

第三步:传输加密数据:

  • 服务端使用对称密钥,发送加密的数据;
  • 客户端使用密钥解密和判断数据是否被篡改了;

img

Q:详细讲一下HTTPS证书验证的过程?

todo

Q:为什么不直接采用RSA,而是采用RSA+对称加密这样的机制?

我的理解是,RSA是一种非对称加密。client 和 server 的通信请求是十分频繁的,而非对称加密虽然对数据的安全性保护好,但是必须考虑到性能。使用非对称加密每次解密是一个很消耗性能和资源的操作,所以为了在安全和性能上达到平衡,使用 非对称对通信密钥加密,在真正通信时使用对称加密解密的方式。

Q:线程池主要有哪些参数?

线程池主要有:

  • 核心线程数;
  • 最大线程数;
  • 超时时间;
  • 时间单位;
  • 阻塞队列
  • 线程工厂;
  • 饱和策略;

Q:线程池的工作机制,拒绝策略有哪些,分别对应于哪些情况?

线程池的工作机制:

  • 当一个任务到达线程池时,会判断线程池中的线程数量:
    • 如果小于核心线程数,创建一个核心线程去执行任务;
  • 如果核心线程数已满,需要判断阻塞队列是否已满:
    • 如果阻塞队列未满,需要直接将任务放入阻塞队列中;
  • 如果阻塞队列已满,需要判断线程池中的线程数和线程池中最大线程数之间的关系:
    • 如果线程数小于最大线程数,创建一个救急线程用于执行任务;
  • 如果线程数已经达到了最大线程数,根据指定的饱和策略去执行这个任务;

拒绝策略:

  • 让当前线程暂停原来的任务,去执行这个任务;
  • 丢弃任务,抛出异常;
  • 直接丢弃任务,不抛出异常;
  • 将阻塞队列中等待最久的,也就是下一个要执行的任务 丢弃掉,然后将该任务放入阻塞队列中;

Q:面向过程和面向对象的理解?

面向过程,是将解决问题的办法抽象成为方法,每次遇到这种问题就直接调用方法;

面向对象,首先需要抽象成对象,然后将解决问题的办法抽象成对象的方法,解决问题是调用对象的方法。

面向对象更具有扩展性和复用性。

Q:讲一下JVM三个类加载器,Tomcat在类加载的具体流程?

三个类加载分别是:

  • 顶层的 BootstrapClassLoader ,是采用 C 语言编写的,用于加载 JDK 的核心类库
  • 扩展类加载器 ,用于加载扩展类库;
  • 应用程序类加载器,用于加载应用程序路径下的所有类;

Tomcat 打破了双亲委派机制,首先会去加载 WEB 目录下的类。

Q:如果采用用户自定义的类加载器的话,它会出现什么样的问题?

我的理解是,如果用户重写了 loadClass() 方法,会打破双亲委派模型的机制。

JVM 在判断一个对象是否是同一个对象时,只有被同一个类加载器的同一个类才是相同的。可能存在两个类加载器加载了同一个类,在进行对象比较时,即使是同一个类,但是会被JVM认为是两个类。

Q:JVM有哪些调优的方法?

这个就说一下JVM调优思路和常见工具吧。

JVM 调优思路主要是从 内存占用 、高吞吐量或低延迟的角度来的。

使用 jps 查看JMV所有的进程状态、jmap 查看堆内存中每个类的实例数量和占用空间,jconsole图形化界面查看JVM各种使用情况。

Q:常见的排序算法,Java的Sort底层是怎么实现的?

冒泡、快排、归并、插入等;

底层是使用双轴快速排序实现的。

Q:详细讲一下快速排序当中具体怎么比较每个元素的(左右指针)?

有一个基准值,首先比较左指针的元素和基准值的大小:

  • 小于基准值,就向右移动左指针;
  • 大于等于基准值,就跳出循环;

然后比较右指针元素和基准值的大小:

  • 大于基准值,就向左移动右指针;
  • 小于基准值,就跳出循环;

此时,交换一次做右指针的元素,移动左右指针,然后重复上述操作,直至指针碰撞;

进行到这里时,一次快排完成,然后分别去左部分和右部分进行快排;

Q:Spring当中的Bean的作用域有哪些?

有singleton、prototype、request、session、application等;

Spring 中 Bean 的作用域通常有下面几种:

  • singleton :

    • IoC 容器中只有唯一的 bean 实例;
    • Spring 中的 bean 默认都是单例的,是对单例设计模式的应用。
  • prototype :

    • 每次获取都会创建一个新的 bean 实例;
    • 连续 getBean() 两次,得到的是不同的 bean 实例。
  • request :

    • 请求 bean
    • 仅 Web 应用可用;
    • 每一次 HTTP 请求都会产生一个新的 bean,该 bean 仅在当前 HTTP request 内有效。
  • session :

    • 仅 Web 应用可用;
    • 会话 bean
    • 每一次来自新 session 的都会产生一个新的 bean,该 bean 仅在当前 HTTP session 内有效。
  • application/global-session

    • 仅 Web 应用可用;
    • 应用 Bean
    • 每个 Web 应用在启动时创建一个 Bean,该 bean 仅在当前应用启动时间内有效。
  • websocket

    • 仅 Web 应用可用;
    • 每一次 WebSocket 会话产生一个新的 bean。

Q:Springboot的启动流程?

启动一个 SpringBoot 工程,大概分为两步。

  • 通过构造函数,创建一个 SpingApplication 实例:
    • 会将,资源加载器(resourceLoader)和主方法类(primarySources)加载到主内存中;
    • 确定 WEB 服务类型,默认是 servlet ,还有 NONEREACTIVE
    • 读取 META-INF/spring.factories 的配置类,进行装配;
    • 定位 main 方法所在的类,就是启动类本身;
  • 执行 SpringApplication.run() 方法:
    • 构建计时器,用于记录 SpringBoot 的启动时间;
    • 初始化监听器,并启动监听,用于监听 run() 方法的执行;
    • 初始化环境;
    • 打印 banner 和 版本;
    • 构造 Spring 容器,填充容器(环境、配置),初始化容器;
    • 监听器监听到启动容器完成,计时器停止计时,打印启动时长;
    • 监听器继续监听正在运行的容器;

Q:介绍一下ApplicationContext?

ApplicationContextSpring 应用程序上下文,相当于是一个容器,负责创建、获取、管理 bean

是高级版本的 BeanFactory ,具有更多的功能,具有事件机制、解析消息支持国际化的能力等。

public interface ApplicationContext extends EnvironmentCapable, ListableBeanFactory, HierarchicalBeanFactory,MessageSource, ApplicationEventPublisher, ResourcePatternResolver {}

最重要的区别是:

BeanFactory 采用的是延迟加载,只有当需要使用到某个 bean 对象时,才会进行加载实例化。这个样子的缺点是,不能及时发现 Spring 的配置问题,如果 bean 的某一个属性没有注入,只有第一次调用 getBean() 时才会抛出异常。

ApplicationContext 是在加载时,就一次性创建了所有的 bean ,有利于检查依赖属性是否注入。在使用 bean 时,无需等待创建,直接拿取就可以使用。缺点就是,占用内存空间,应用程序配置的 bean 很多时,启动会比较慢。

并且 BeanFactory 通常以编程的方式被创建,而 ApplicationContext 是声明的方式去创建。

Q:有 A,B 两个文件(50亿个URL)每个URL具有64B的大小,4GB内存,怎么找到这两个文件所含有的公共URL?

也可以采用布隆过滤器,但是我个人认为不太好。

采用分治的思想:

  • 利用一个 hash 函数,分别遍历 A,B 文件中的所有数据,将其拆分成小文件进行存储;
  • 遍历 A 中的小文件,利用一个 hashSet 存储,然后同样遍历 B 小文件判断是否存在 Set 中存在该元素,如果是则表明是相同的 url ,进行存储即可。

img

2.美团后端一面

美团后端一面

Q:反射的理解,应用举例?

todo

Q:ThreadLocal原理,项目中用到了,又结合起来问了一些场景?

todo

Q:线程池核心参数?

todo

Q:丢弃策略一般使用什么比较好?

todo

Q:mysql索引,事务等等,说你知道的?

todo

Q:如何考虑索引效率问题,比如命中,索引大小,合理性问题等等?

todo

3.动态规划

  • 300. 最长递增子序列(⭐⭐⭐)
    public int lengthOfLIS(int[] nums) {/*** 最长递增子序列的长度,严格递增* dp[i],代表数组下标从[0,i]的最长递增子序列的长度* 每个元素的最长递增子序列的长度,最少为1*/int[] dp = new int[nums.length];Arrays.fill(dp, 1);int res = 0;for (int i = 0; i < nums.length; i++) {for (int j = 0; j < i; j++) {// 只有当nums[i] > nums[j] 时,才需要判断if (nums[i] > nums[j]) {dp[i] = Math.max(dp[i], dp[j] + 1);}}res = Math.max(res, dp[i]);}return res;}
  • 674. 最长连续递增序列(⭐⭐⭐⭐⭐)
    public int findLengthOfLCIS(int[] nums) {/*** 最长且连续递增的子序列,要求该序列中的每个元素都是递增的* dp[i]代表以元素下标i结尾时,最长且连续递增的子序列的长度*/int length = nums.length;int res = 1;int[] dp = new int[length];dp[0] = 1;for (int i = 1; i < length; i++) {// 只有当当前元素大于前一个元素时,才计算if (nums[i] > nums[i - 1]) {dp[i] = dp[i - 1] + 1;} else {dp[i] = 1;}res = Math.max(dp[i], res);}return res;}
  • 718. 最长重复子数组(⭐⭐⭐⭐⭐)
    public int findLength(int[] nums1, int[] nums2) {/*** 最长重复子数组:*  返回两个数组中 公共的、长度最长的子数组的长度*  dp[i][j]代表nums1[0,i-1]结尾和nums2[0,j-1]结尾的公共的、长度最长的子数组的长度*/int[][] dp = new int[nums1.length + 1][nums2.length + 1];int res = 0;for (int i = 1; i <= nums1.length; i++) {for (int j = 1; j <= nums2.length; j++) {if (nums1[i - 1] == nums2[j - 1]) {dp[i][j] = dp[i - 1][j - 1] + 1;}if (dp[i][j] > res) {res = dp[i][j];}}}return res;}
  • 1143. 最长公共子序列
    public int longestCommonSubsequence(String text1, String text2) {/*** 一个字符串的子序列,可以删除某些字符,只需要保证相对顺序不变* dp[i][j],表示text1下标末尾为[0,i-1]和text2下标为[0,j-1]的最长公共子序列*/int m = text1.length();int n = text2.length();int[][] dp = new int[m + 1][n + 1];for (int i = 1; i <= m; i++) {for (int j = 1; j <= n; j++) {if (text1.charAt(i - 1) == text2.charAt(j - 1)) {// 如果两个字符相等dp[i][j] = dp[i - 1][j - 1] + 1;} else {// 由于字符可以维持相对顺序,删除,所以不等的情况下,逻辑是这个样子的dp[i][j] = Math.max(dp[i - 1][j], dp[i][j - 1]);}}}return dp[m][n];}
  • 1035. 不相交的线(⭐⭐⭐⭐⭐)- 第一眼毫无思路
    public int maxUncrossedLines(int[] nums1, int[] nums2) {/*** 泪目了* 看似是求两个数组中的最大连接线数,其实是求两个数组的最长公共子序列*/int m = nums1.length;int n = nums2.length;int[][] dp = new int[m + 1][n + 1];for (int i = 1; i <= m; i++) {for (int j = 1; j <= n; j++) {if (nums1[i - 1] == nums2[j - 1]) {dp[i][j] = dp[i - 1][j - 1] + 1;} else {dp[i][j] = Math.max(dp[i - 1][j], dp[i][j - 1]);}}}return dp[m][n];}
  • 53. 最大子数组和
    public int maxSubArray(int[] nums) {/*** dp[i] ,是以数组下标为 i 结尾的最大和*/int[] dp = new int[nums.length];dp[0] = nums[0];int res = nums[0];for (int i = 1; i < nums.length; i++) {// 判断当前值和之前的大小dp[i] = Math.max(dp[i - 1] + nums[i], nums[i]);res = dp[i] > res ? dp[i] : res;}return res;}
  • 392. 判断子序列(⭐⭐⭐⭐⭐)- 这个真的有点难,注意画图推导
    public boolean isSubsequence(String s, String t) {/*** dp[i][j] 是以 i-1 结尾的s,是否是 j-1 结尾的子序列*/int m = s.length();int n = t.length();int[][] dp = new int[m + 1][n + 1];for (int i = 1; i <= m; i++) {for (int j = 1; j <= n; j++) {if (s.charAt(i - 1) == t.charAt(j - 1)) {dp[i][j] = dp[i - 1][j - 1] + 1;} else {dp[i][j] = dp[i][j - 1];}}}return dp[m][n] == s.length();}
  • 583. 两个字符串的删除操作
    public int minDistance(String word1, String word2) {/*** 我的思路是,找到word1和word2的最长子序列的长度*/int m = word1.length();int n = word2.length();int[][] dp = new int[m + 1][n + 1];for (int i = 1; i <= m; i++) {for (int j = 1; j <= n; j++) {if (word1.charAt(i - 1) == word2.charAt(j - 1)) {dp[i][j] = dp[i - 1][j - 1] + 1;} else {dp[i][j] = Math.max(dp[i - 1][j], dp[i][j - 1]);}}}int length = dp[m][n];return word1.length() + word2.length() - 2 * length;}
  • 115. 不同的子序列
    public int numDistinct(String s, String t) {/*** dp[i][j]:以i-1为结尾的s子序列中出现以j-1为结尾的t的个数为dp[i][j]。*/int m = s.length();int n = t.length();int[][] dp = new int[m + 1][n + 1];for (int i = 0; i <= m; i++) {dp[i][0] = 1;}for (int i = 1; i <= m; i++) {for (int j = 1; j <= n; j++) {if (s.charAt(i - 1) == t.charAt(j - 1)) {dp[i][j] = dp[i - 1][j - 1] + dp[i - 1][j];} else {dp[i][j] = dp[i - 1][j];}}}return dp[m][n];}

总结

提示:这里对文章进行总结:

最近要加紧速度学习呀,总结和复习很重要。

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

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

相关文章

4.21 用了 TCP 协议,数据一定不会丢吗?

目录 数据包的发送流程: 建立连接时丢包 流量控制丢包 网卡丢包 RingBuffer过小导致丢包 网卡性能不足 接收缓冲区丢包 两端之间的网络丢包 ping命令查看丢包&#xff1a; mtr命令&#xff1a; 发生丢包了怎么办 用了TCP协议就一定不会丢包吗​编辑 这类丢包问题怎…

WebGL 绘制函数gl.drawArrays

gl.drawArrays&#xff08;&#xff09;的第1个参数 WebGL方法gl.drawArrays&#xff08;&#xff09;既强大又灵活&#xff0c;通过给第1个参数mode指定不同的值&#xff0c;在这个参数上指定不同的值&#xff0c;我们可以按照不同的规则绘制图形。 下图中的7种基本图形是We…

Docker容器:docker consul的注册与发现及consul-template守护进程

文章目录 一.docker consul的注册与发现介绍1.什么是服务注册与发现2.什么是consul3.consul提供的一些关键特性4.数据流向 二.consul部署1.consul服务器&#xff08;192.168.198.12&#xff09;&#xff08;1&#xff09;建立 Consul 服务&#xff08;2&#xff09;查看集群信息…

Elasticsearch配置优化

以下的优化基础是安装的 Elasticsearch 版本为 7.17.7&#xff0c;同时jdk版本为 1.8.321 1、jvm参数优化 这里说的jvm参数调优&#xff0c;是指elasticsearch安装目录下的jvm.options配置&#xff0c;如下图所示&#xff1a; 这里调整的内容主要是调整垃圾回收的收集器&#…

基于YOLOV8模型的人脸口罩目标检测系统(PyTorch+Pyside6+YOLOv8模型)

摘要&#xff1a;基于YOLOV8模型的人脸口罩目标检测系统可用于日常生活中检测与定位人脸口罩&#xff0c;利用深度学习算法可实现图片、视频、摄像头等方式的目标检测&#xff0c;另外本系统还支持图片、视频等格式的结果可视化与结果导出。本系统采用YOLOv8目标检测算法训练数…

threejs纹理加载三(视频加载)

threejs中除了能把图片作为纹理进行几何体贴图以外&#xff0c;还可以把视频作为纹理进行贴图设置。纹理的类型有很多&#xff0c;我们可以用不同的加载器来加载&#xff0c;而对于视频作为纹理&#xff0c;我们需要用到今天的主角&#xff1a;VideoTexture。我们先看效果&…

Pyside6的使用方法

一.创建一个简单的Qt小部件应用程序 1.Imports 导入相应的模块 PySide6 Python 模块提供对 Qt API 的访问作为其子模块。在本例中&#xff0c;您将导入 QtCore、QtWidgets 和 QtGui 子模块。 import sys import random from PySide6 import QtCore, QtWidgets, QtGui #只导入…

C++day3(类、this指针、类中的特殊成员函数)

一、Xmind整理&#xff1a; 二、上课笔记整理&#xff1a; 1.类的应用实例 #include <iostream> using namespace std;class Person { private:string name; public:int age;int high;void set_name(string n); //在类内声明函数void show(){cout << "na…

vue2.6及以下版本导入 TDesign UI组件库

TDesign 官方文档:https://tdesign.tencent.com/vue/components/button 我们先打开一个普通的vue项目 然后 如果你是 vue 2.6 或者 低于 2.6 在终端执行 npm i tdesign-vue如果你是 2.7 或者更高 执行 npm i tdesign-vuenaruto这里 我们 以 2.6为例 因为大部分人 用vue2 都是…

JAVA坦克大战游戏v3

JAVA坦克大战游戏v3 素材 bomb_3.gif bomb_2.gif bomb_1.gif 项目结构 游戏演示 MyTankGame3.java /*** 功能:坦克游戏的5.0[]* 1.画出坦克.* 2.我的坦克可以上下左右移动* 3.可以发射子弹,子弹连发(最多5)* 4.当我的坦克击中敌人坦克时&#xff0c;敌人就消失(爆炸的效…

3dsMax软件安装包分享(附安装教程)

目录 一、软件简介 二、软件下载 一、软件简介 3dsMax是一款由Autodesk公司开发的著名的三维计算机图形软件&#xff0c;广泛应用于动画、游戏、建筑和产品设计等领域。它以强大的建模、动画、渲染和特效功能而闻名&#xff0c;为用户提供了一个完整的制作流程&#xff0c;从…

使用Jetpack Compose构建可折叠Card

使用Jetpack Compose构建可折叠Card 为何在Android应用开发中使用扩展卡片 扩展卡片在Android应用开发中广受欢迎&#xff0c;它们可以让开发者打造干净紧凑的用户界面&#xff0c;同时可以轻松展开&#xff0c;显示额外的内容。 通过巧妙地使用扩展卡片&#xff0c;开发者可…

十四、pikachu之XSS

文章目录 1、XSS概述2、实战2.1 反射型XSS&#xff08;get&#xff09;2.2 反射型XSS&#xff08;POST型&#xff09;2.3 存储型XSS2.4 DOM型XSS2.5 DOM型XSS-X2.6 XSS之盲打2.7 XSS之过滤2.8 XSS之htmlspecialchars2.9 XSS之href输出2.10 XSS之JS输出 1、XSS概述 Cross-Site S…

当图像宽高为奇数时,如何计算 I420 格式的uv分量大小

背景 I420 中 yuv 数据存放在3个 planes 中。 网上一般说 I420 数据大小为 widthheight1.5 但是当 width 和 height 是奇数时&#xff0c;这个计算公式会有问题。 I420 中 u 和 v 的宽高分别为 y 的一半。 但是当不能整除时&#xff0c;是如何取整呢&#xff1f;向上还是向下&…

2. 使用IDEA创建Spring Boot Hello项目并管理依赖——Maven入门指南

前言&#xff1a;本文将介绍如何使用IDEA创建一个Spring Boot Hello项目&#xff0c;并通过Maven来管理项目的依赖。我们从项目的创建到代码的编写&#xff0c;再到项目的构建和运行&#xff0c;一步步演示了整个过程。 &#x1f680; 作者简介&#xff1a;作为某云服务提供商的…

有什么react进阶的项目推荐的?

前言 整理了一些react相关的项目&#xff0c;可以选择自己需要的练习&#xff0c;希望对你有帮助~ 1.ant-design Star&#xff1a;87.1k 阿里开源的react项目&#xff0c;作为一个UI库&#xff0c;省去重复造轮子的时间 仓库地址&#xff1a;https://github.com/ant-design/…

《JVM修仙之路》初入JVM世界

《JVM修仙之路》初入JVM世界 博主目前正在学习JVM的相关知识&#xff0c;想以一种不同的方式记录下&#xff0c;娱乐一下 清晨&#xff0c;你睁开双眼&#xff0c;看到刺眼的阳光&#xff0c;你第一反应就是完了完了&#xff0c;又要迟到了。刚准备起床穿衣的你突然意识到不对&…

畜牧兽医虚拟仿真|病禽解剖VR模拟操作演练系统

在生物学课程中&#xff0c;动物解剖是一个重要的组成部分&#xff0c;它能够帮助学生了解动物的生理结构、功能和生活习性&#xff0c;从而更好地认识和保护自然界的生物多样性。然而&#xff0c;传统的动物解剖教学方法往往局限于课堂教学和实验室实践&#xff0c;学生很难真…