面经学习(杭州实在智能实习)

个人评价

秃狼觉得本次的面试是有史以来难度最大的,问了很多陌生的八股文,项目问的比较少,估计是项目本来就没有什么亮点,也是第一次被面试官说菜的面试。不过在后续的学习上还是收获颇丰的。

1.说说你在实习中遇到的难点吧?

我们的实现项目主要就是做C端的在线教育项目,也是因为我是实习生的原有,我没有去负责黄金链路,也就是从用户登录到用户下单课程最后到用户观看视频的整个流程。我主要负责辅助模块的开发,包括 评论,点赞,视频点播模块的开发。

我说说我印象比较深的难点,当时需求就是完成续播的效果,在我们的点播记录表中会记录观看到的位置,因为我们视频播放采用的是腾讯VOD来实现的,也就是视频的长度使用整型表示 。并且上级的要求误差要控制在30秒之内。续播的功能本质就是操作数据库,并且前端每隔15秒就会提交对应的观看位置,如果直接打数据库的话,请求量大的话最终就会压垮数据库。为了解决这个问题,我们通过讨论使用的解决方案就是 redis的hash结构 + 定时任务来解决的。本质就是减少DB操作,redis的hash结构,大key存储课表id,课表id用于关联课程和userId,小key存储节的Id,value存储观看的位置。在每次发送请求的时候都修改hash结构并且使用RabbitMq的死信队列实现的延迟信息(延迟15秒)、发送一个当前的观看位置的消息。在监听到消息之后使用当前的观看位置和消息中的观看位置,如果二者相同的话,就说明当前15内没有再观看了,这时候去修改数据库,反之,丢掉对应的消息。在性能的上,减少了99%的db操作。

2.在做合并写请求的时候,RabbitMq发送消息的速度大于消费者消费的速度,怎么解决?

本质上就是消费者的消费速度小于生产速度。解决这个问题的主要方案就是:增加我们的消费者个数,加快消费者的消费速度,对我们消息队列进行扩容。

1.增加消费者个数:因为项目采用的是微服务落地方案,所以我们可以增加消费者的节点。

2.加快消费者的消费速度:我们可以创建线程池,创建多线程进行消费。

3.消息队列进行扩容:当在默认情况下我们的消息队列不足的时候,我们可以对消息队列进行扩容,可以使用惰性队列进行扩容,因为惰性队列使用磁盘进行存储,所以在读取的时候速度上比较慢,所以还是要根据业务情况进行选择。

3.在Spring中怎么解决循环依赖的问题?

Spring中使用三级缓存来解决缓存依赖,一级缓存主要就是存储完整的实例,二级缓存主要就是次存储代理对象,三级缓存就是ObjectFactory。当A和B相互依赖的时候就是使用三级缓存。

加载A,并将A的ObjectFactory存放到三级缓存,去加载B,并将B的ObjectFactory存放到三级缓存中。当发现B中需要依赖A,此时将使用A的ObjectFactory生成A的代理对象,并将A的代理对象存放到二级缓存中,将A注入到B中,将完整的B存放到一级缓存中,此时回溯,将完整的B注入到A中,最终解决三级缓存的问题。

问:除了三级缓存还有什么解决方案吗?

我们还可以使用@Lazy注解,当发生循环依赖的时候,就比如此时A->B <--> B->A,我们会在A中的B属性上添加@Lazy,在我们需要依赖B的时候就会生成B的代理对象,完成A的实例化,最终再完成B的实例化。

4.Spring中的事务有了解过吗?

Spring的事务主要解决的问题就是并发事务带来的问题。

Spring的实现方式主要就是使用Aop的来实现的,使用环绕通知,在执行方法的时候,开启事务,并对执行的方法使用Try/catch,如果捕获异常的话就进行回滚,如果执行完方法后就进行提交。

Spring中的事务传播性主要包括: Propagation_Required(公用同一个事务),Propagation_Required_new(开启新事务),Propagation_nested,在住事务中内嵌子事务,当主事务不存在的时候,就会创建新事务。

5.动态代理的流程有了解过吗?

动态代理主要就是JDK动态代理和CGLIB动态代理,被当代理对象有实现接口的时候就会直接使用JDK的动态代理,当被代理对象没有实现接口的时候,就会使用CGLIB的动态代理,将继承被代理对象的子类作为代理对象。

6.B树和B+树的区别?

B树会在每一个节点上存放数据,而B+树则在叶子节点存储数据。

区别最大的我认为是:因为B树在结构特性,导致在做范围查询的时候需要多次从根节点出发,而B+树则不需要。并且在做排序的时候B+树也很方便,因为叶子节点使用双向链表进行存储。

7.Spring中的设计模式有哪些?

单例模式:我比较了解就是Spring中IOC默认情况下采用的就是单例模式。

工厂模式和策略模式:我们当时在实现动态获取分布式锁及对应策略,使用自定义注解+工厂模式+策略模式。自定义注解主要就是控制对应的枚举。我们会创建一个工厂类,里面有一个属性EunmMap,key存储对应的枚举,value存储对应分布式锁的实现方法,最终设置枚举即可获得对应的类。策略模式则就会在枚举中编写一个抽象方法,会有多个方法实现该抽象方法,最终这些实现的方法就是策略。

责任链模式:最常见的就是Stream流式编程,通过返回原型继续执行方法。

8.voliate是线程安全的吗?

voliate主要解决的就是线程共享变量的可见性,及防止指令重排序。

当我们的程序在执行很大的循环时,由于JIT的优化机制,就会使大循环变成无限循环,导致线程间无法读取到修改后的共享变量。也是因为JDK优化的问题,为了提高运行效率,在执行指令的时候会对指令进行重排序。

但是呢,voliate在执行的过程中不遵循原子性,所以不是线程安全的。

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

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

相关文章

K8S内存资源配置

在 Kubernetes (k8s) 中&#xff0c;资源请求和限制用于管理容器的 CPU 和内存资源。配置 CPU 和内存资源时&#xff0c;使用特定的单位来表示资源的数量。 CPU 资源配置 CPU 单位&#xff1a;Kubernetes 中的 CPU 资源以 “核” (cores) 为单位。1 CPU 核心等于 1 vCPU/Core…

SpringBoot RestHighLevelClient 按版本更新

SpringBoot RestHighLevelClient 按版本更新 1 查询2 更新 RestHighLevelClient 是 Elasticsearch 提供的一个用于与 Elasticsearch 集群交互的高级 REST 客户端。它是基于 Java 的客户端&#xff0c;旨在提供一种简单且功能丰富的方式来执行各种 Elasticsearch 操作&#xff0…

2024年海峡两岸创业青年研学交流项目火热开展中

7月17日&#xff0c;由浙江外国语学院国际商学院、创业学院主办的“文化之舟系两岸&#xff0c;潮头勇立浙商旗”——2024年海峡两岸大学生&#xff08;创业青年&#xff09;研学交流项目持续进行中。 上午&#xff0c;邵波副教授带领学生代表接待来自台湾的二十多名学生参加“…

利用 PHP 解锁 1688 详情 API 接口的秘密

在电商领域的探索中&#xff0c;1688 平台的商品详情数据无疑是一座宝藏。而通过 PHP 语言来解锁 1688 详情 API 接口的秘密&#xff0c;将为我们开启获取这一宝藏的大门。 一、深入了解 1688 详情 API 接口 1688 详情 API 接口提供了丰富的商品信息&#xff0c;包括商品描述、…

Linux输出重定向到文件立即输出

./md.out > output.txt 2>&1程序中断时&#xff0c;文件为空的原因可能是由于缓冲机制。标准输出&#xff08;stdout&#xff09;和标准错误输出&#xff08;stderr&#xff09;默认是缓冲的&#xff0c;这意味着数据在写入文件之前会先存储在缓冲区中。如果程序在缓…

【人工智能】在未来智慧城市的建设及应用分析

作者主页: 知孤云出岫 目录 作者主页:案例分析&#xff1a;人工智能在未来智慧城市的建设及其影响和应用引言一、人工智能在智慧城市中的关键应用领域 案例分析&#xff1a;人工智能在未来智慧城市的建设及其影响和应用 引言 智慧城市是利用信息和通信技术&#xff08;ICT&am…

电平的概念及应用(电路节点在某一时刻的电压状态)(高电平、低电平)(电压是推动电荷通过导体的力,而电平是这种力的表达形式)

文章目录 电平的概念及其在电子与电气应用中的应用1. 电平的基本概念1.1 电压与电平1.2 电流与电压的区分 2. 数字电路中的电平应用2.1 逻辑电平2.1.1 TTL电平2.1.2 CMOS电平 2.2 电平转换 3. 模拟电路中的电平应用3.1 信号表示3.2 信号放大 4. 电平在通信技术中的应用4.1 RS-4…

迁移学习在乳腺浸润性导管癌病理图像分类中的应用

1. 引言 乳腺癌主要有两种类型:原位癌:原位癌是非常早期的癌症&#xff0c;开始在乳管中扩散&#xff0c;但没有扩散到乳房组织的其他部分。这也称为导管原位癌(DCIS)。浸润性乳腺癌:浸润性乳腺癌已经扩散(侵入)到周围的乳腺组织。侵袭性癌症比原位癌更难治愈。将乳汁输送到乳…

Android Navigation 组件原理和使用教程

Android Navigation 组件是用于简化导航相关操作的框架&#xff0c;允许你在应用中管理应用内各个部分之间的导航。该组件是Android Jetpack的一部分&#xff0c;主要包含三个部分&#xff1a;导航图&#xff08;NavGraph&#xff09;、NavHost和NavController。 一、原理 Nav…

Kafka Producer之幂等性

文章目录 1. 启用幂等性2. 底层变化3. 数据不重复4. 数据有序 幂等性通过消耗时间和性能的方式&#xff0c;解决乱序和重复问题。 但是只能保证同一生产者在一个分区中的幂等性。 1. 启用幂等性 //创建producerHashMap<String, Object> config new HashMap<>();…

怎样在 PostgreSQL 中优化对大表的分区裁剪和索引选择?

&#x1f345;关注博主&#x1f397;️ 带你畅游技术世界&#xff0c;不错过每一次成长机会&#xff01;&#x1f4da;领书&#xff1a;PostgreSQL 入门到精通.pdf 文章目录 怎样在 PostgreSQL 中优化对大表的分区裁剪和索引选择一、分区裁剪&#xff1a;精准切割&#xff0c;提…

SQL Server 和 MySQL 的主要区别

架构 SQL Server 微软开发&#xff0c;闭源商业数据库运行在 Windows 和 Linux单一数据库引擎架构支持多个数据库实例和多种数据存储机制&#xff08;行存储和列存储&#xff09;包含数据库引擎、SQL Server Agent、SQL Server Reporting Services (SSRS)、SQL Server Integrat…

【自学安全防御】三、企业双机热备和带宽管理的综合实验

实验拓扑&#xff1a; 实验任务&#xff1a; 12&#xff0c;对现有网络进行改造升级&#xff0c;将当个防火墙组网改成双机热备的组网形式&#xff0c;做负载分担模式&#xff0c;游客区和DMZ区走FW3&#xff0c;生产区和办公区的流量走FW1 13&#xff0c;办公区上网用户限制流…

QML基本类型

QML基本数据类型之 int使用案例代码 <span style"color:#4b4b4b"><span style"background-color:#ffffff"><code class"language-JavaScript"><span style"color:#008000">// 定义 >> 整型&#xff08…

go-zero框架入门

go-zero框架环境的安装 goctl 若想用go-zero框架&#xff0c;还需要一些前置条件&#xff1a; 安装goctl go install github.com/zeromicro/go-zero/tools/goctllatest可以使用 goctl 命令查看是否安装成功 成功后安装protoc goctl env check --install --verbose --force…

如何免费用java c#实现手机在网状态查询

今天分享手机在网状态查询接口&#xff0c;该接口适用的场景非常广泛&#xff01;首先我们先讲下什么是手机在网状态&#xff1f;简单来说&#xff0c;就是你得手机号是否还在正常使用中&#xff0c;是否能够及时接收和回复信息&#xff0c;是否能够随时接听和拨打电话。如果你…

【Android】基础—基本布局

【Android】基础—基本布局 基本布局 线性布局 垂直方向&#xff1a; <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android"android:orientation"vertical"…

深度学习根据代码可视化模型结构图的方法

方法1. Netron Netron 是一个支持多种深度学习模型格式的可视化工具&#xff0c;可以将 PyTorch 模型转换为 ONNX 格式&#xff0c;然后使用 Netron 进行可视化。 安装 Netron&#xff1a; pip install netron使用示例&#xff1a; import torch.onnx# 定义模型 model EMA…

趣谈linux操作系统 9 网络系统-读书笔记

文章目录 网络协议栈基础知识回顾网络分层网络分层的目的各层作用简介延伸-ip地址,有类,无类,cidr socket实现分析tcp/udp回顾socket编程回顾TCP编程回顾UDP编程回顾差异 socket相关接口实现浅析sokcet实现解析创建socket的三个参数socket函数定义及其参数创建socket结构体关联…

k8s学习——升级后的k8s使用私有harbor仓库

升级后的k8s使用了第三方的容器管理器&#xff0c;安装了nerdctl工具来替代docker进行镜像管理。但是使用docker build打包并上传至harbor仓库的镜像&#xff0c;在部署过程中始终拉不下来&#xff0c;报错证书错误。通过journalctl -xe |grep kubelet 或 journalctl -xe |grep…