入我新美大的Java后台开发面试题总结

  静儿最近在总结一些面试题,那是因为做什么事情都要认真。面试也一样,静儿作为新美大金融部门的面试官,负责任的告诉大家,下面的问题回答不上来,面试是过不了的。不过以下绝不是原题,你会发现自己实力不过硬,最终肯定是被问出来的。

  1>如何定位线上服务OOM问题 

      2>JVM的GC ROOTS存在于那些地方

      3>mysql innodb怎样做查询优化

  4>java cas的概念

  下面静儿就以自己面试的标准简单回答一下这些题怎样回答算过关。

  1>如何定位线上服务OOM问题

  因为面试主要是看思路,答案还是其次,那么要是我回答这个问题。我可能会把整个思路都说出来:Java服务OOM,比较常见的原因是

  ⭐️ 有可能是内存分配确实过小,而正常业务使用了大量内存

    比如jmap -heap命令可以查看新生代老年代的堆内存大小及使用情况,看看是否内存本身分配过小。

  ⭐️ 某一个对象被频繁申请,却没有释放,内存不断泄漏,导致内存耗尽

    比如jmap -histo:live 对象显示存活对象的信息,并按照所占内存大小的排序。因为包含了实例数、所占内存大小、类名,所以很直观。

  ⭐️ 某一个资源被频繁申请,系统资源耗尽,例如:不断创建线程,不断发起网络连接  

    可以用pstree、netstat查看进程创建线程数,网络连接数,如果资源耗尽,也会出现OOM。也可以查看/proc/${PID}/fd  和/proc/${PID}/task,查看句柄详情和线程数。

  2>JVM的GC ROOTS存在于那些地方

   问到这个问题应该是前面一步步引导过来的,如果没有,在直接回答这个问题之前,最好简要描述一下JVM的内存结构和根搜索算法(GC ROOTS Tracing)做可达性分析。

  GC Roots的对象包括如下几种(静儿来新美大的时候就被我们架构师问过这个问题):

  ⭐️  虚拟机栈(栈桢中的本地变量表)中的引用的对象

  ⭐️  方法区中的类静态属性引用的对象

  ⭐️  方法区中的常量引用的对象

  ⭐️  本地方法栈中JNI的引用的对象

  GC管理的主要区域是Java堆,一般情况下只针对堆进行垃圾回收。方法区、栈和本地方法区不被GC所管理,因而选择这些区域作为GC ROOTS。被GC ROOTS引用的对象不会被垃圾回收。

  3>mysql innodb怎样做查询优化

  这个问题的答案就比较多了,各人的心得都是不一样的。主要考察在工作实践中的总结和思考能力。最好面试者能在总结的通用答案之后加上实际项目中的使用例子。

  ⭐️  innodb_buffer_pool_size 此参数的作用是缓冲数据和索引,对性能可以产生线性的提高,最大可设置为内存大小的百分之七八十的样子

  ⭐️  打开慢查询日志,增加参数:log-queries-not-using-indexes,方便把系统中没有走索引的sql语句全抓出来优化

  ⭐️  通过explain做查询分析,看看有没有用索引,访问的行数rows

  ⭐️  关闭skip_name_resolve,减少逆向DNS解析的消耗

  另外还有一些实际写代码过程中深入骨髓的,比如数据动静分离提高query_cache的命中率啦,减少字段冗余,减少查询次数啦,复杂查询分解啦,分页优化啦啥的。

  很多人说面试题和实际开发联系不大,觉得没啥用。其实很多活培训两个月都是能干的。人和人之间的差距确实没有明显到你能干我不能干的程度。但是之前做过一个项目,我和别人一起干,干完之后我要修改很多其他人的各种慢查询问题啦,性能问题啦之类。我看了他们写的sql,我发现这些sql我会理所当然不那么用的。因为我在人人的时候就很注意这些方面,我认为是理所当然的,知道这样影响性能。

  还有就是面试评价好的人实际写代码的时候确实出的问题要少,因为他们考虑更全面。很多人不是有意要出bug的,但是确实是不知道啊,不知道要考虑情况A,情况B,不知道JVM底层的实现,所以有可能会产生的意想不到的结果。出了问题了也不知道往哪个方向去想。

  4>java cas的概念

  cas:compare and swap,比较并交换

  java的concurrent包中借助cas实现了区别于synchronized同步锁的一种乐观锁。

  CAS利用CPU的CAS指令,同时借助JNI来完成java的非阻塞算法,其他的原子操作都是利用类似的特性完成的。java的concurrent包相对于使用synchronized性能提升也是主要依赖于它。

跑题时间:

这几年万圣节都会买南瓜自己做南瓜灯。我给小鲜肉在美国买的西餐刀非常安全,我都是把南瓜洗干净,旁边放一个干净铁盆,让小鲜肉自己雕刻南瓜灯,我睡觉去。因为我承诺了要用做南瓜灯剩下的边角料给他做南瓜饼,所以睡觉起来会看到桌子上很干净。记得有一年我觉得浪费,把南瓜顶上的盖也做着吃了,小鲜肉很生气,我们只好第二天一起去超时重买了一个小贝贝南瓜重做了一个南瓜灯。

  南瓜饼可以直接将南瓜煮熟放糖放面粉做成饼油炸。用牛奶来和面味道更好。我总习惯捏出来各种动物形状做一盘外焦里嫩的动物大餐。但是如果是一整个南瓜,那就蒸成9分熟之后和面粉一起用杵捣,捣的时间越长越有弹性。这个工作当然是交给小鲜肉来做的。但是这样就不好捏成形状了,只用勺子弄成球下锅。油锅开始时是小火,南瓜饼熟的差不多了,再开大点火,外面酥脆,里面松软。

  只可惜现在都是很忙,周末也只是办公间隙里去给小鲜肉做点小点心。记得原来总是特别清闲,找工作也总是不给自己加压,说自己不做管理。过着管好自己就可以的生活。有次带着小鲜肉去华科看牡丹,看到一个姑娘悠闲的躺在长椅上晒太阳。这可不就是原来的自己。悠然的过了那么多年,告诉自己“有花堪折直须折”,早就做好了准备接受现在的一切,而真的到来的时候,除了庆幸自己想要做的都试过了,还是多少有些伤感。

  男神在我手机上看我的BOSS直聘。我说:“人家老公查媳妇手机都是看看媳妇到底跟谁聊了天,都聊了啥,你看你”。男神漫不经心的说:“对啊,关心啊,所以把你手机没收了。”然后接着看BOSS直聘。

  别看周末是这样的,平时我忙的都不回家,也就是周末才回家一趟。每天男神都给我请安,问我是否活着。他最近改了头像,头像是东软的一条小道,因为原来我俩在东软的时候每天早晨我俩都刚好能在那条小道上打个照面。从那以来,两个人就是彼此牵挂、彼此信任、一起努力的往前走。奋斗是很辛苦,如果一个人的话是很难坚持。两个人相互鼓励的往前走,想要放弃的时候,总是不忍心让对方失望,于是就实现了一个又一个的目标。

  男神最近在一路开挂的面试,面试过程中收获了一打年轻漂亮的猎头和HR。因为他换工作的理由是:“我想找个离媳妇近的工作,每天接送媳妇上下班。”我相信我家男神的自制力,看到男神的offer薪资秒杀我,我赶紧发个短信问他:“以后你这么牛逼了,还能每周给我洗衣服吗?”男神毫不犹豫的回了个:“能”。结果周末回家告诉我我上周的衣服还有几件没洗的,让我有空自己洗吧,我突然觉得天儿咋这么冷呢。还幻想着劝我家男神来我们新美大,像以前我在人人的时候一样,每周末来给我收拾工位呢。不来也好,旁边站着一个女神收割机,我压力也是有的。

  当一个人站在自己面前,其实自己心里是很清楚的。谁是合适的,谁是喜欢的。而到底谁是对的人取决于自己的人生规划。规划着想要幸福就选合适的,天生为才艺而生的人会选喜欢的。如果来生还是今世的重复,纵然多情要比无情苦。痛苦才是才艺的源泉,经历过才会感同身受。原来看过一个从零维空间到十维空间的,突然觉得之前遇见过的人都是其中一个维度的选择,只是自己不喜欢那个选择,于是在这个空间里做了调整。

  一个人做了一场梦,醒来感叹梦而已。实际上做梦的时候,体内有数以万计的细胞终其一生只为演绎这场梦境。谁又能肯定自己不是别人梦境中的一个细胞呢。所以呢,别把自己太当回事,演绎好自己,好梦!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏程序人生

谈谈分布式系统

先讲个黑色笑话: 半年前,一个谁也没见过的日本浪人推出的理财产品突然在七侠镇火爆起来,据说买上点屯着,不出几月就能把同福客栈,甚至龙门镖局都盘下。我们家小六的七...

31510
来自专栏张戈的专栏

详解Linux系统的CPU负载均值

上一篇文章的最后,作者提到了文章的参考来源,我特意前往访问了下,发现写得非常不错,特转过来,可以结合阅读,以便更容易理解 CPU 负载这个概念。 你可能对于 L...

4159
来自专栏牛客网

阿里 & 酷家乐:实习生面试

最近海投了十家公司,暂时有阿里两面(已凉)、酷家乐两面(大概凉了)、网易一面。前两个都是基础知识发挥得还可以,两家公司二面都凉凉。 阿里一面(3.21 26mi...

4184
来自专栏贾老师の博客

《帝国时代》中的网络编程

1204
来自专栏CSDN技术头条

刘奇:如何使用HBase构建NewSQL?

目前主流的数据库或者NoSQL要么在CAP里面选择AP,比较典型的例子是Cassandra,要么选择CP比如HBase,这两个是目前用得非常多的NoSQL的实现...

1915
来自专栏PHP技术

浅谈12306 核心模型设计思路和架构设计

原文出处: 汤雪华 前言 春节期间,无意中看到一篇文章, 文章中讲到12306的业务复杂度远远比淘宝天猫这种电商网站要复杂。后来自己想想,也确实如此。所以,很...

4427
来自专栏LET

CPU简介

1889
来自专栏逍遥剑客的游戏开发

一些VR延迟优化方法

2197
来自专栏aCloudDeveloper

用户空间网络提升 NFV 的性能

本文是一篇翻译,翻译自https://software.intel.com/en-us/blogs/2015/06/12/user-space-network...

2723
来自专栏WeTest质量开放平台团队的专栏

5天2亿活跃用户,2017QQ“LBS+AR”天降红包活动后台揭密

作者王家彬,腾讯后台开发工程师,参与“LBS+AR”天降红包项目,其所在“2016春节红包联合项目团队”获得2016公司级业务突破奖。

1263

扫码关注云+社区