Java后端每日面试题(day6)

目录

创建线程的方式


线程常用的几种创建方式为:

  • 继承Thread类;

  • 实现Runnable接口;

  • 实现Callable接口;

  • 使用ExecutorService线程池。

锁的分类

公平锁与非公平锁


按照线程 访问顺序 获取对象锁。synchronized是非公平锁,Lock默认是非公平锁,可以设置为公平锁,公平锁会影响性能。

共享式与独占式锁


共享式与独占式的最主要区别在于:
同一时刻独占式只能有一个线程获取同步状态,而共享式在同一时刻可以有多个线程获取同步状态。

例如读操作可以有多个线程同时进行,而写操作同一时刻只能有一个线程进行写操作,其他操作都会被阻塞。

悲观锁与乐观锁


悲观锁,每次访问资源都会加锁,执行完同步代码释放锁,synchronizedReentrantLock属于悲观锁。

乐观锁,不会锁定资源,所有的线程都能访问并修改同一个资源,如果没有冲突就修改成功并退出,否则就会继续循环尝试。乐观锁最常见的实现就是CAS

适用场景

悲观锁适合写操作多的场景。

乐观锁适合读操作多的场景,不加锁可以提升读操作的性能

rbac相关的表


RBAC(Role-Based Access Control,基于角色的访问控制)是一种常用的访问控制机制,用于管理系统中的用户权限。

RBAC通过将用户分配给角色,并将权限授予角色,从而控制用户对资源的访问。

基于RBAC实现的权限管理通常需要涉及以下几张表:

spring security原理


对于servlet三大组件,spring security位于Filter过滤链中,SpringSecurity 本质就是一个过滤器链

SpringSecurity 采用的是责任链的设计模式,它有一条很长的过滤器链

DelegatingFilterProxy

Spring 提供了一个 DelegatingFilterProxy 代理类,DelegatingFilterProxy 实现了Filter,因此它可以被注入到 FilterChain(过滤器链)中,同时,当请求到来时,它会把请求转发到Spring容器 中实现了Filter接口的 Bean 实体,DelegatingFilterProxy会从ApplicationContext中获取FilterBean 实体,然后将请求转发给到它,所以 DelegatingFilterProxy 桥接了 Servlet容器 和 Spring容器。

FilterChainProxy

DelegatingFilterProxy从Spring容器中获取得到的就是FilterChainProxy实体,而FilterChainProxy也是一个代理类,它最终会将请求转发到 Spring Security 提供的SecurityFilterChain中,FilterChainProxy就是 Spring Security 真正的入口起始点

SecurityFilterChain

SecurityFilterChain作用其实跟Servlet的FilterChain一样,同样维护了很多Filters,这些Filters 是由Spring Security提供的,每个 Security Filter 都有不同的职能,比如登录认证、CSRF防御...

Spring Security 作用机制大致如下:

  1. 注册标准Filter :首先,会自动注入一个DelegatingFilterProxy到 Servlet 的FilterChain中。
  2. 请求转发到 Spring Security :当请求到来时,DelegatingFilterProxy就会自动在 Spring容器 中搜索名称为springSecurityFilterChain的Filter实体,其实际类型为FilterChainProxy。DelegatingFilterProxy最终会将请求转发给到FilterChainProxy。
  3. 找到匹配请求处理的SecurityFilterChain :FilterChainProxy内部维护了一系列SecurityFilterChains,他会依据请求内容找到对应处理该请求的SecurityFilterChain。
  4. 请求处理:找到能处理请求的第一个SecurityFilterChain后,就会遍历该SecurityFilterChain内部维护的一系列Filters,依次让这些 Security Filter 处理该请求,完成认证、授权等功能。

mybatis一对一,一对多


一对一

<resultMap> <association>

<association> 元素,通常可以配置一下属性

  • propery:指定映射到实体类对象属性,与表字段一一对应
  • column:指定表中对应的字段
  • javaType:指定映射到实体对象属性的类型
  • select:指定引入嵌套查询的子SQL语句,该属性用于关联映射中的嵌套查询
  • fetchType :指定在关联查询时是否启用延迟加载。FetchType属性有 lazyeager(实时)两个属性值,默认值为 lazy
    默认为lazy(默认关联映射延迟加载)

一对多

<resultMap> <collection>

使用Mapper注解,实现一对一和一对多关系查询

xml 复制代码
<resultMap id="userMap" type="com.beiyou.model.User">
    <id column="id" property="id"/>
    <result column="tel" property="tel"/>
    <result column="password" property="password"/>
    <!--一对一-->
    <association property="userInfo" column="Id"  fetchType="lazy" javaType="com.beiyou.model.UserInfo"
     select="selectUserinfo">
        <id property="id" column="id"/>
        <result property="name" column="name"/>
        <result property="sex" column="sex"/>
    </association>
     <!--一对多-->
    <collection property="addresses" column="id" fetchType="lazy" javaType="java.util.ArrayList"
           ofType="com.beiyou.model.Address"  select="selectAddress" >
        <id property="id" column="id"/>
        <result property="province" column="province"/>
        <result property="city" column="city"/>
        <result property="county" column="county"/>
        <result property="address" column="address"/>
    </collection>
</resultMap>
相关推荐
SmallBambooCode3 分钟前
【Flask】在Flask应用中使用Flask-Limiter进行简单CC攻击防御
后端·python·flask
杰九1 小时前
【全栈】SprintBoot+vue3迷你商城(10)
开发语言·前端·javascript·vue.js·spring boot
ThisIsClark2 小时前
【后端面试总结】mysql的join,left join,right join,full join分别是什么意思
mysql·面试·职场和发展
栗豆包3 小时前
w179基于Java Web的流浪宠物管理系统的设计与实现
java·开发语言·spring boot·后端·spring·宠物
伟大的python程序员3 小时前
thinkphp6+swoole使用rabbitMq队列
后端·rabbitmq·swoole
组合缺一3 小时前
无耳科技 Solon v3.0.7 发布(2025农历新年版)
java·后端·科技·solon
天使day4 小时前
SpringCloud两种注册中心
java·spring·spring cloud
小韩学长yyds5 小时前
解锁跨平台通信:Netty、Redis、MQ和WebSocket的奇妙融合
java·spring boot·redis·websocket
三次拒绝王俊凯5 小时前
java求职学习day15
java·学习·面试
言之。5 小时前
【架构面试】二、消息队列和MySQL和Redis
java·面试·架构