前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >偏测试技术面试,高频面试题分享

偏测试技术面试,高频面试题分享

原创
作者头像
周辰晨
发布2024-04-28 10:41:23
1690
发布2024-04-28 10:41:23
举报
文章被收录于专栏:Java小册

一.介绍下你们公司产品的后端模块?

以电商微服务架构示例:

  1. 用户服务 (User Service):
    • 负责用户注册、登录、个人信息管理等功能。
    • 存储用户数据,如用户名、密码、个人资料等。
  2. 商品服务 (Product Service):
    • 管理商品信息,包括商品的增删改查、库存管理等。
    • 负责处理商品分类、推荐、搜索等功能。
  3. 订单服务 (Order Service):
    • 处理订单的创建、支付、取消、物流跟踪等流程。
    • 管理订单状态、历史订单记录等。
  4. 支付服务 (Payment Service):
    • 处理支付过程,与第三方支付平台接口对接。
    • 管理支付状态、退款等相关逻辑。
  5. 购物车服务 (Cart Service):
    • 管理用户的购物车信息,加入商品、删除商品、结算等操作。
  6. 评论与评分服务 (Review and Rating Service):
    • 用户可以对商品进行评价及评分,提供评论功能。
  7. 推荐服务 (Recommendation Service):
    • 基于用户行为和偏好向用户推荐商品,增加个性化体验。
  8. 搜索服务 (Search Service):
    • 提供商品搜索功能,支持关键词搜索、筛选、排序等。
  9. 权限与安全服务 (Security Service):
    • 负责用户权限管理、安全认证、访问控制等。
  10. 日志与监控服务 (Logging and Monitoring Service):
    • 收集微服务的日志信息、监控服务运行状态,确保系统稳定性和性能。

微服务架构特点和优势:

  • 独立部署与扩展: 每个微服务可以独立部署和扩展,便于管理和维护。
  • 松耦合性: 不同微服务间通过API相互通信,降低了耦合度,提高了灵活性。
  • 技术栈多样性: 不同微服务可以使用不同的技术栈,根据需求选择最适合的技术。
  • 容错和隔离性: 单个微服务出现故障不会影响整个系统,具有更好的容错性和隔离性。

二.基于RPC有哪些常见框架

  1. gRPC:
    • gRPC 是由Google开发的高性能、跨语言的开源RPC框架,基于HTTP/2协议和Protocol Buffers。
    • 支持多种语言(如Java、C++、Python等),提供强大的编解码和接口定义功能。
  2. Apache Dubbo:
    • Dubbo是一款高性能的Java RPC框架,由阿里巴巴开源,支持丰富的特性如负载均衡、服务治理、动态扩展等。
    • 擅长处理大规模分布式系统中的服务调用和管理。
  3. Apache Thrift:
    • Thrift是由Facebook开发并开源的跨语言的RPC框架,支持多种语言。
    • 可以生成多种语言的客户端和服务端代码,并提供了序列化协议的支持。
  4. Spring Cloud:
    • Spring Cloud为构建分布式系统提供了多个项目,其中包括Spring Cloud Netflix、Spring Cloud Consul等,用于服务注册与发现、负载均衡、断路器等功能。
    • Spring Cloud可以与RESTful服务、Dubbo等整合,提供灵活的微服务架构支持。
  5. Thrift:
    • Apache Thrift是一个跨语言的RPC框架,支持多种常见语言。
    • 可生成不同语言对应的接口定义和客户端/服务端代码,使跨语言调用变得更加简便

三.Java垃圾回收过程

Java的垃圾回收过程一般包括以下步骤:

1. 标记阶段 (Marking Phase):

  • 垃圾回收器首先从根对象(如栈、静态变量等)出发,标记所有能够被访问到的对象为活动对象。
  • 所有未标记的对象将被标记为待回收对象。

2. 清除阶段 (Sweeping Phase):

  • 在清除阶段,不再使用的对象会被删除,释放内存空间。
  • 未被标记的对象将被清除,这些未被标记的对象被认定为垃圾。

3. 压缩阶段 (Compacting Phase - Optional):

  • 在一些垃圾回收算法中,压缩阶段将执行内存碎片整理,将存活的对象向内存的一侧移动,以便给新对象分配更连续的内存空间。

四.写个内存泄漏的demo

代码语言:txt
复制
import java.util.ArrayList;
import java.util.List;
public class MemoryLeakDemo {
 private static List<Integer> list = new ArrayList<>();
 public void addToMemoryLeakList(int number) {
 list.add(number);
 }
 public static void main(String[] args) {
 MemoryLeakDemo demo = new MemoryLeakDemo();
 for (int i = 0; i < 1000000; i++) {
 demo.addToMemoryLeakList(i);
 }
 // 假设这里应该清空list,但是忘记清空导致内存泄漏
 // list.clear();
 System.out.println("Memory leak demo done.");
 }
}

五.什么情况下索引失效

  1. 未使用索引字段进行查询: 当查询条件不包括任何索引字段,数据库优化器可能会选择不使用索引而进行全表扫描,导致索引失效。
  2. 函数操作符导致索引失效: 在查询条件中使用函数、操作符或者类型转换可能导致索引无法被利用。比如在 WHERE 子句中使用 LIKE '%value%' 或者对字段进行 FUNCTION() 操作。
  3. 数据类型不匹配: 如果在条件中对字段进行了数据类型的转换,比如将数字字段转换为字符串进行比较,可能会导致索引失效。
  4. 不满足索引的最左前缀规则: 复合索引中,如果查询条件未按照索引的从左到右的顺序使用字段,索引可能不会被有效利用。
  5. 使用 OR 条件: 当 OR 条件连接的查询条件中只有部分条件使用了索引,可能导致索引失效。
  6. 查询条件使用 IS NULL 或 <> NULL: 在查询中使用 IS NULL 或 <> NULL 的条件可能导致索引失效。
  7. 表数据量较小: 当表中的数据量较小时,数据库优化器可能会选择全表扫描而不使用索引。
  8. 数据分布不均匀: 如果数据分布不均匀,一些值的重复率较高,可能导致数据库选择不使用索引。
  9. 频繁的数据更新: 对于频繁更新的字段,在更新时可能导致索引失效,需要谨慎设计索引策略。

六.什么是单例模式

单例模式是一种创建型设计模式,其目的是确保一个类只有一个实例,并提供一个全局访问点来访问这个实例。在单例模式中,类的实例化过程被限制在一个对象,并提供一个全局的访问点来获取该实例。这种模式通常用于控制对唯一实例的访问,如全局配置、日志记录器、数据库连接等场景。

七.Python中装饰器的作用

在Python中,装饰器是一种函数,它可以接受一个函数作为参数,并返回一个新的函数。装饰器用于给函数动态地添加额外的功能,而不修改函数本身的代码。装饰器在Python中用于很多场景,比如日志记录、性能分析、权限检查等。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档