中软国际Java机试,阿里Java算法题
拼多多三面惨败,java中间件、数据库与spring框架,答不上…
面试开火箭,工作拧螺丝…月初有个朋友面试拼多多,一面自信满满过了,结果三面却惨败…昨天朋友约我出来讨论问题在哪里,三面就答不上了(卡壳很严重呐)。听完整个面试经历之后,我总结了一下,这次拼多多一二三面其实综合总结起来就问了五个方面的东西,分别是自我介绍+项目、java基础、中间件、数据库和spring框架,另外还问了道算法题。接下来就跟大家一起来看看拼多多的面经,看看你是否能轻松应对面试官的炮轰?
一、对象的实例化
1.创建对象的方式
new:最常见的方式(本质是构造器)
变形1 : Xxx的静态方法
变形2 : XxBuilder/XxoxFactory的静态方法
Class的newInstance():反射的方式,只能调用空参的构造器,权限必须是public
Constructor的newInstance(Xxx):反射的方式,位于java.lang.reflect.Constructor 可以调用空参、带参的构造器,权限没有要求
使用clone() :不调用任何构造器,当前类需要实现Cloneable接口,实现clone()
使用反序列化:从文件中、从网络中获取一个对象的二进制流
第三方库Objenesis
2.创建对象的步骤
1.判断对象对应的类是否加载、链接、初始化
虚拟机遇到一条new指令,首先去检查这个指令的参数能否在Metaspace的常量池中定位到一个类的符号引用,并且检查这个符号引用代表的类是否已经被加载、解析和初始化。( 即判断类元信息是否存在)。
如果没有,那么在双亲委派模式下,使用当前类加载器以ClassLoader+包名+类名为Key进行查找对应的.class文件。如果没有找到文件,则抛出ClassNotFoundException异常,如果找到,则进行类加载,并生成对应的Class类对象
2.为对象分配内存
首先计算对象占用空间大小,接着在堆中划分一块内存给新对象。 如果实例成员变量是引用变量,仅分配引用变量空间即可,即4个字节大小。
- 如果内存规整,使用指针碰撞
如果内存是规整的,那么虚拟机将采用的是指针碰撞法(BumpThePointer)来为对象分配内存。意思是所有用过的内存在一边,空闲的内存在另外一边,中间放着一个指针作为分界点的指示器,分配内存就仅仅是把指针向空闲那边挪动一段与对象大小相等的距离罢了。如果垃圾收集器选择的是Serial、ParNew这种基于压缩算法的,虚拟机采用这种分配方式。所以一般使用带有compact(整理)过程的收集器时,使用指针碰撞。 - 如果内存不规整,虚拟机需要维护一个列表,使用空闲列表分配
如果内存不是规整的,已使用的内存和未使用的内存相互交错,那么虛拟机将采用的是空闲列表法来为对象分配内存。意思是虚拟机维护了一个列表,记录上哪些内存块是可用的,再分配的时候从列表中找到一块足够大的空间划分给对象实例,并更新列表上的内容。这种分配方式成为“空闲列表(Free List) ”。
说明:选择哪种分配方式由Java堆是否规整决定,而Java堆是否规整又由所采用的垃圾收集器是否带有压缩整理功能决定。
3.处理并发安全问题
在分配内存空间时,另外一个问题是及时保证new对象时候的线程安全性:创建对象是非常频繁的操作,虚拟机需要解决并发问题。虚拟机采用 了两种方式解决并发问题:
- CAS ( Compare And Swap )失败重试、区域加锁:保证指针更新操作的原子性;
- TLAB把内存分配的动作按照线程划分在不同的空间之中进行,即每个线程在Java堆中预先分配一小块内存,称为本地线程分配缓冲区,(TLAB ,Thread Local Allocation Buffer) 虚拟机是否使用TLAB,可以通过一XX:+/一UseTLAB参数来 设定。
4.初始化分配到的空间
Java给对象的属性赋值的操作有如下四种:
- 属性的默认初始化
- 显式初始化
- 代码块中初始化
- 构造器中初始化
内存分配结束,虚拟机将分配到的内存空间都初始化为零值(不包括对象头)。这一步保证了对象的实例字段在Java代码中可以不用赋初始值就可以直接使用,程序能访问到这些字段的数据类型所对应的零值。
5.设置对象的对象头
将对象的所属类(即类的元数据信息)、对象的HashCode和对象的GC信息、锁信息等数据存储在对象的对象头中。这个过程的具体设置方式取决于JVM实现。
6.执行init方法进行初始化
在Java程序的视角看来,初始化才正式开始。初始化成员变量,执行实例化代码块,调用类的构造方法,并把堆内对象的首地址赋值给引用变量。 因此一般来说(由字节码中是否跟随有invokespecial指令所决定),new指令之 后会接着就是执行方法,把对象按照程序员的意愿进行初始化,这样一个真正可用的对象才算完全创建出来。
二、对象的内存布局
1.对象头(Header)
包含两部分
- 运行时元数据
- 哈希值( HashCode )
- GC分代年龄
- 锁状态标志
- 线程持有的锁
- 偏向线程ID
- 偏向时间戳
- 类型指针:指向类元数据的InstanceKlass,确定该对象所属的类型
说明:如果是数组,还需记录数组的长度
2.实例数据(Instance Data)
说明:它是对象真正存储的有效信息,包括程序代码中定义的各种类型的字段(包括从父类继承下来的和本身拥有的字段) 规则:
- 相同宽度的字段总被分配在一起
- 父类中定义的变量会出现在子类之前
- 如果CompactFields参数为true(默认为true),子类的窄变量可能插入到父类变量的空隙
3.对齐填充(Padding)
不是必须的,也没特别含义,仅仅起到占位符作用
最后
针对最近很多人都在面试,我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。
下面的面试题答案都整理成文档笔记。也还整理了一些面试资料&最新2021收集的一些大厂的面试真题(都整理成文档,小部分截图)
最新整理电子书
真题(都整理成文档,小部分截图)
[外链图片转存中…(img-grvh2uw5-1650267818761)]
最新整理电子书
[外链图片转存中…(img-vV1wsDO8-1650267818762)]
中软国际Java机试,阿里Java算法题相关推荐
- 无锡中软国际有限公司笔试题(Java)附加个人答案版
昨天把这套题做了一下 也许存在很多问题 望大家多多指教! 无锡中软国际有限公司笔试题(Java) (本卷总分100分,60分及格,时间60分钟) 一,不定项选择题(每小题3分,共15题,总计45分) ...
- 中软国际python机试题_中软国际笔试试题
中软国际校园招聘笔试试题 考试范围: 1 .逻辑推理题(共 20 分) 2 .开发技术题(共 60 分) 3 .软件工程知识题(共 20 分) 考试要求: 1 .考试时间为 60 分钟,每个人独立完成 ...
- 中软国际python机试题_中软国际入职机试题.doc
中软国际入职机试题 1 邮箱地址合法性验证,合法输出字符"1",不合法输出字符"0" 合法条件: A 仅包含一个"@". B 最后三位必须是 ...
- 中软国际python机试题_【中软国际员工笔试试题及答案】 - 面试网
中软国际员工笔试试题及答案: 一.选择题 1.IP地址126.168.0.1属于哪一类IP地址( ) A.D类 B.C类型 C.B类 D.A类 2.以下哪一个设置不是上互联网所必须的( ) A.IP地 ...
- 中软国际python机试题_【中软国际c语言开发笔试试题及答案】 - 面试网
中软国际c语言开发笔试试题及答案: 一 选择 1.在一个C程序中( ) [A] main函数必须出现在所有函数之前 [B] main函数可以在任何地方出现 [C] main函数必须出现在所有函数之后 ...
- 无锡中软国际有限公司笔试题(Java)
(本卷总分100分,60分及格,时间60分钟) 一,不定项选择题(每小题3分,共15题,总计45分) 1.下面哪些是合法的变量名? () A.2variable B..variable2 C.._wh ...
- 中软python机试_中软国际python机试题_中软国际笔试试题
考试范围: 1 .逻辑推理题(共 20 分) 2 .开发技术题(共 60 分) 3 .软件工程知识题(共 20 分) 考试要求: 1 .考试时间为 60 分钟,每个人独立完成考试 2 .须在" ...
- 中软国际python机试题_中软国际入职机试题[优质资料]
资料 - 参考 1 1 邮箱地址合法性验证,合法输出字符" 1 ",不合法输出字符" 0 " 合法条件: A 仅包含一个" @ ". B 最 ...
- 中软国际入职java考核_中软国际技术人员入职试题2(Java)
中软国际技术人员入职试题2(Java) Java 笔试试题 一.介绍JSP中常用的内部对象.(时间4分钟) 1 request 2 response 3 out 4 application 5 ses ...
- 中软国际java面试题及参考答案
面试题是中软国际java个人求职者在面试过程中的敲门砖,以下是小编为大家收集到的,希望对大家有帮助! :填空题 1Java语言具有许多优点和特点,下列选项中,哪个反映了Java程序并行机制的特点 B ...
最新文章
- 网站SEO优化该如何提高用户粘度?
- php 使用postfix发邮件,PHP处理postfix邮件内容的方法
- MySQL存储引擎MyISAM和 InnoDB
- 动态规划 POJ 1088 滑雪
- 现代软件工程系列 学生的精彩文章 (6) 项目总结
- 形象易懂讲解算法I——小波变换
- 01_配置管理和SaltStack概述
- C语言做出3D效果的程序,3D数学库的简单实现(C语言)
- Snipaste贴图软件及其快捷键使用方法
- Linux下如何查看硬盘型号、序列号、缓存 CPU 主板 等信息
- 数据可视化,2022的春运地图
- 四大蓝牙天线设计方式
- 一个西瓜 4刀最多多少块
- Python中的XOR异或符号^运用
- 00942 oracle_Oracle物化视图创建报ORA-00942错误解决
- css clip-path
- 中国(杭州)跨境电子商务综合试验区的实践和探索
- 华为云物联网平台的C#应用开发(基本接口调用)
- Android手机Root失败的五大重要原因
- opencv证件照背景替换
热门文章
- php损坏的图像,php – 复制后图像损坏
- 服务器2012r2安装虚拟,Windows Server 2012 R2 安装VMware Tools的正确姿势(实现物理机和虚拟机文件互传)...
- 测试面试基础问答(加解析)
- 小米强势进军欧洲市场,接连开出专卖店
- Windows下PostgreSQL的用户口令问题
- 9 大免费好用的文件恢复软件 [2023精选工具]
- [iOS开发]常用弹窗总结
- OpenGL 入门基础教程 —— 彩色立方体
- 开启MongoDB更新文档操作的正确姿势
- python实现概率论与数理统计_《统计思维:程序员数学之概率统计》读书笔记