1 List集合 1.1 List概述 在Collection中,List集合是有序的,可对其中每个元素的插入位置进行精确地控制,可以通过索引来访问元素,遍历元素. 在List集合中,我们常用到ArrayList和LinkedList这两个类. 关于Java List的一些重要观点是; Java List接口是Java Collections Framework的成员.List允许您添加重复元素.List允许您拥有'null'元素.List接口在Java 8中有许多默认方法,例如replaceA…
Java 内存分配 • 寄存器:程序计数器,是线程私有的,就是一个指针,指向方法区中的方法字节码.• 静态域:static 定义的静态成员.• 常量池:编译时被确定并保存在 .class 文件中的(final)常量值和一些文本修饰的符号引用(类和接口的全限定名,字段的名称和描述符,方法和名称和描述符). • 非 RAM 存储:硬盘等永久存储空间.• 堆内存:new 创建的对象和数组,由 Java 虚拟机自动垃圾回收器管理,存取速度慢.• 栈内存:基本类型的变量和对象的引用变量(堆内存空间的访问地…
前言: 最近也是在后台收到很多小伙伴私信问我线程和线程池这一块的问题,说自己在面试的时候老是被问到这一块的问题,被问的很头疼.前几天看到后帮几个小伙伴解决了问题,但是问的人有点多我一个个回答也回答不过来,干脆花了一个上午时间写了这篇文章分享给大家.话不多说,满满的干货都在下面了! 并发与并行 并发:指两个或多个事件在同一个时间段内发生.在操作系统中,安装了多个程序,并发指的是在一段时间内宏观上有多个程序同时运行,这在单 CPU 系统中,每 一时刻只能有一道程序执行,即微观上这些程序是分时的交替运…
本文是字节跳动数据平台开发套件团队在1月9日Flink Forward Asia 2021: Flink Forward 峰会上的演讲分享,将着重分享Flink在字节跳动数据流的实践. 字节跳动数据流的业务背景 数据流处理的主要是埋点日志.埋点,也叫Event Tracking,是数据和业务之间的桥梁,是数据分析.推荐.运营的基石. 用户在使用App.小程序.Web等各种线上应用时产生的行为,主要通过埋点的形式进行采集上报,按不同的来源分为客户端埋点.Web端埋点.服务端埋点. 不同来源的埋点都…
Spring框架是一个为Java应用程序的开发提供了综合.广泛的基础性支持的Java平台.Spring帮助开发者解决了开发中基础性的问题,使得开发人员可以专注于应用程序的开发. 近两年来,许多大厂在面试中都会频繁问到Spring相关,记得第一次去阿里面试时,可以说是惨遭“虐待”,被面试官逼问得哑口无言,尤其是Spring部分,基本上是一问三不知,也怪自己没有做好准备,所以才交了白卷. 离上次面试阿里失败之后,回去狠狠复习了一波,这次离上次的面试已经过去半年了,如今已经成功拿下阿里offer,即将…
  一般问题 1.1. 不同版本的 Spring Framework 有哪些主要功能?   1.2. 什么是 Spring Framework? Spring 是一个开源应用框架,旨在降低应用程序开发的复杂度. 它是轻量级.松散耦合的. 它具有分层体系结构,允许用户选择组件,同时还为 J2EE 应用程序开发提供了一个有凝聚力的框架. 它可以集成其他框架,如 Structs.Hibernate.EJB 等,所以又称为框架的框架. 1.3. 列举 Spring Framework 的优点. 由于 S…
Zookeeper概述 zookeeper高容错数据一致性协议(CP)的分布式小文件系统,提供类似于文件系统的目录方式的数据存储. 全局数据一致性:每个server保存一份相同的数据副本,client无论连接到哪个server展示的数据都是一致的. 可靠性:一旦事务成功提交,就会被保留下来. 有序性:客户端发起的事务请求,在也会顺序的应用在Zookeeper中. 数据更新原子性:一次数据更新要么成功要么失败,不存在中间状态. 实时性:保证客户端在一个间隔时间范围内获取服务的更新消息或服务器失效信…
这篇文章将深入探讨Spring框架的一部分——Spring Web MVC的强大功能及其内部工作原理. 项目安装 在本文中,我们将使用最新.最好的Spring Framework 5.我们将重点介绍Spring的经典Web堆栈,该堆栈从框架的第一个版本中就崭露头角,并且现在依然是用Spring构建Web应用程序的主要方式. 对于初学者来说,为了安装测试项目,最好使用Spring Boot和一些初学者依赖项:还需要定义parent: <parent> <groupId>org.spr…
前言 我大概我是从去年12月份开始看书学习,到今年的6月份,一直学到看大家的面经基本上百分之90以上都会,我就在5月份开始投简历,边面试边补充基础知识等.也是有些辛苦.终于是在前不久拿到了字节跳动的offer,现在我也来写面经,希望能帮助到大家! 面经 Java基础 0.HashMap的源码,实现原理,JDK8中对HashMap做了怎样的优化. 拉链结构,数组+链表,原理是hash找数组,冲突后拉链表,1.8优化为会进化成红黑树提高效率,并且使用2^n来做容量值 引申点: equal & has…