转载:你积累了什么?

转自:http://hi.baidu.com/linkzq/item/36adc0ab7ca7e4a929ce9dfd

开始用JBE看class文件时,发现new指令后都跟着dup操作,翻了《深入Java虚拟机指令》也没什么结果,Google后转到“诗剑书生”的CSDN专栏,这个问题得到了答案。再顺着下去看其它的博文,有个问题开始给了我危机感。

      说是他的兄弟部门招聘一个Java平台的架构师,请他代为面试,这位前来面的仁兄有15年的编程经验,12年Java经历(大部分时间做CRM、AO,也有互联网应用的项目经验),历经N多的公司,看起来底子不薄。面试的过程让人意外:

01>谈谈一般工作流中流程引擎处理的对象模型.

   答:我做的都是特定于某个需求的流程,不了解通用的工作流处理的原理.(十五年的经验不知道一点模型抽象,一直在造轮子).

02>谈谈WEB应用中大规模用户高并发需求的网站架构一般原则.

   答:(内容不少,但主要是以一几点)
     1.负载均衡,
2 cache(自己介绍一个投票系统,用户投票数据直接放在cache中).3数据库读写分离.

03>如何做数据库读写分离,谈谈你做过的经验.

   答:我自己没做过这些方案,就是看过这样的方案介绍.

04>如果新增数据也放在cache中,如何保证出现异常时数据不丢失?

   答:我可以在容器关闭前写到数据库,平时每10分钟与数据库同步一次.

05>对于大规模用户的WEB应用,10分钟可能上百万的数据,要是突然宕机来不及同步到数据库怎么办?

   答:.......................没考虑过.

06>网站的负载均衡有哪些模型?

   答:没有做过,按照我的理解就是多点分布.

07>那你谈谈自己最熟悉的技术点在哪方面?

   答:JAVA技术方面,比如多线程.

08>OK,那我们聊聊JAVA技术.JVM底层技术有了解吗?

   答:这个当然了解.

09>请用你知道的知识描述一下GC的工作原理.

   答:一个对象没有引用的时候就可以被回收.

10>那么怎么知道对象没有引用了呢?

   答:这个不知道.

11>GC是如何分代的?

   答:什么分代?我不了解.

12>关于GC还了解哪些?

   答:其它的不清楚,我记得只要对象没有引用就可以回收了.

13>OK,多线程方面,jdk5以后的concurrent包中的数据结构用过哪些?

   答:数据结构是什么意思?

14>就是相当于java.util下面的容器类.

   答:我用过threadpoolexecutor.

15>我问的是数据结构或叫容器,比如说List,Map这类的数据结构.

   答:没有用过,我平时用的都是同步之类多线程(意思是1.5之前的并发编程类库).

16>OK,请简单画一下JAVA的内存模型.

   答:内存模型?不了解,我画不出来.

17>那么请说说volatile关键字在JAVA5之前有什么作用.

   答:没听说过这个关键字.

18>那么,进入同步块和离开同步块时,变量是如何同步的?

   答:这些底层的东西我都不了解,主要是做应用层。

19>主要做应用层,那么熟悉使用的框架吗?

   答:是啊.struts,hibernate,spring这些框架比较熟悉。

20>hibernate中,l1,l2的cache,给一个经验值.

   答:没有做过.我主要是使用它的功能,都是默认设置.

21>volecity中,如果我要在渲染到页面之前统一对内容进行拦截处理应该如何做?

   答:做一个filter,在请求进来的时候拦截.

22>我说的是 velocity中渲染到页面之前的拦截.

   答:这个我不知道.

23>那你谈谈你平时做哪些工作.

   答:用jsp,struts,hibernate,spring做业务逻辑.

24>十几年都是做这些吗?

   答:以前没有这些框架,就是用JSP连接数据库.

25>你使用这些"东西"这么久,有对这些"东西"的原理研究过吗?或者去读一下它们的源码.

   答:没有.就是一直在用.

看着以上的问题,想着将来如果我努力的方向也是架构师,该怎么办?该怎么办?

原文地址:https://www.cnblogs.com/ribavnu/p/3180386.html