更多面试题请看这里:https://interview.raoyunsoft.com/
面试题专栏会持续更新欢迎关注订阅
一、传统布局
-
线性布局(LinearLayout)
- 用法 :按水平或垂直方向排列子视图,通过
orientation属性控制方向 - 特点 :
- 简单直观,适合线性排列场景
- 权重(
layout_weight)实现比例分配
- 效率 :
- 单层布局效率高
- 多层嵌套时测量次数指数级增长(O(n²))
- 用法 :按水平或垂直方向排列子视图,通过
-
相对布局(RelativeLayout)
- 用法 :通过相对定位(如
layout_toRightOf)确定子视图位置 - 特点 :
- 灵活处理视图间相对关系
- 减少嵌套层级
- 效率 :
- 需两次测量(依赖关系解析)
- 优于多层嵌套的LinearLayout
- 用法 :通过相对定位(如
-
帧布局(FrameLayout)
- 用法:子视图堆叠显示,后添加的覆盖在先添加视图上层
- 特点 :
- 适用于悬浮按钮/全屏弹窗
- 默认左上角对齐,需手动定位
- 效率 :
- 测量速度快(仅需一次遍历)
- 过度使用易导致过度绘制
-
表格布局(TableLayout)
- 用法 :以行列形式组织子视图,需配合
TableRow使用 - 特点 :
- 自动对齐行列
- 支持列拉伸(
stretchColumns)
- 效率 :
- 行列计算开销较大
- 不适合动态增删单元格
- 用法 :以行列形式组织子视图,需配合
-
绝对布局(AbsoluteLayout - 已过时)
⚠️ 已被ConstraintLayout替代,不推荐使用
- 用法:通过精确坐标(x,y)定位
- 缺点 :
- 无法适配不同屏幕尺寸
- 维护困难
二、新型布局
约束布局(ConstraintLayout)
-
用法 :
- 通过约束关系(基线/边距/比例)定位视图
- 支持可视化拖拽设计
-
核心优势 :
xml<Button app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintTop_toTopOf="parent"/> -
排版效率 :
-
扁平化结构:减少90%+嵌套层级
-
测量优化:单次测量完成复杂布局(优于RelativeLayout)
-
性能表现 :
布局类型 测量次数 适用场景 LinearLayout嵌套 O(n²) 简单列表 RelativeLayout O(2n) 中等复杂度 ConstraintLayout O(1) 复杂响应式界面
-
三、性能优化建议
- 减少嵌套:ConstraintLayout替代多层LinearLayout
- 避免过度绘制:帧布局层级≤3层
- 复用布局 :
<include>标签复用公共组件 - 动态加载:ViewStub延迟加载复杂模块
关键结论:ConstraintLayout通过约束关系和扁平化设计,在复杂界面中显著提升渲染性能(60fps达标率提升40%+),已成为现代Android开发的首选布局。