急求java面试题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了急求java面试题相关的知识,希望对你有一定的参考价值。

1.在hibernate中当一个数据很大时怎么处理
2.long 型的很大的数,不用string,char的api如何实现反转
3.怎样用hashmap实现一个tree
4.请写一个简单的线程池
5.String str = "yes" if (str == "no") str += "ok" 一共创建了几个对象
6.项目的最大的处理流量是多少
7.怎么处理多台数据服务器之间session 和cookie得问题
8.Hibernate中解决n+1次查询的方法
9.什么是Checked Exception,Unchecked Exception?
10.描述一下JAVA ClassLoader 或者J2EE ClassLoader的工作原理
11.SQLserver、ORACLE、mysql中实现分页的机制各是什么
12.Dom4j如何使用
13.单列模式3个特点
14.解释spring的工作机制

spring 容器 内部工作机制

Spring的AbstractApplicationContext是ApplicationContext抽象实现类,该抽象类的refresh()方法定义了Spring容器在加载配置文件后的各项处理过程,这些处理过程清晰刻画了Spring容器启动时所执行的各项操作。下面,我们来看一下refresh()内部定义了哪些执行逻辑:

1.初始化BeanFactory:根据配置文件实例化BeanFactory,getBeanFactory()方法由具体子类实现。在这一步里,Spring将配置文件的信息装入到容器的Bean定义注册表(BeanDefinitionRegistry)中,但此时Bean还未初始化;
2.调用工厂后处理器:根据反射机制从BeanDefinitionRegistry中找出所有BeanFactoryPostProcessor类型的Bean,并调用其postProcessBeanFactory()接口方法;
3.注册Bean后处理器:根据反射机制从BeanDefinitionRegistry中找出所有BeanPostProcessor类型的Bean,并将它们注册到容器Bean后处理器的注册表中;
4.初始化消息源:初始化容器的国际化信息资源;
5.初始化应用上下文事件广播器;
6.初始化其他特殊的Bean:这是一个钩子方法,子类可以借助这个钩子方法执行一些特殊的操作:如AbstractRefreshableWebApplicationContext就使用该钩子方法执行初始化ThemeSource的操作;
7.注册事件监听器;
8.初始化singleton的Bean:实例化所有singleton的Bean,并将它们放入Spring容器的缓存中;
9.发布上下文刷新事件:创建上下文刷新事件,事件广播器负责将些事件广播到每个注册的事件监听器中。
在第3.4节中,我们观摩了Bean从创建到销毁的生命历程,这些过程都可以在上面的过程中找到对应的步骤。Spring协调多个组件共同完成这个复杂的工程流程,图5-1描述了Spring容器从加载配置文件到创建出一个完整Bean的作业流程以及参与的角色。

图5-1 IoC的流水线
1.ResourceLoader从存储介质中加载Spring配置文件,并使用Resource表示这个配置文件的资源;
2.BeanDefinitionReader读取Resource所指向的配置文件资源,然后解析配置文件。配置文件中每一个<bean>解析成一个BeanDefinition对象,并保存到BeanDefinitionRegistry中;
3.容器扫描BeanDefinitionRegistry中的BeanDefinition,使用Java的反射机制自动识别出Bean工厂后处理器(实现BeanFactoryPostProcessor接口)的Bean,然后调用这些Bean工厂后处理器对BeanDefinitionRegistry中的BeanDefinition进行加工处理。主要完成以下两项工作:
1)对使用到占位符的<bean>元素标签进行解析,得到最终的配置值,这意味对一些半成品式的BeanDefinition对象进行加工处理并得到成品的BeanDefinition对象;
2)对BeanDefinitionRegistry中的BeanDefinition进行扫描,通过Java反射机制找出所有属性编辑器的Bean(实现java.beans.PropertyEditor接口的Bean),并自动将它们注册到Spring容器的属性编辑器注册表中(PropertyEditorRegistry);
4.Spring容器从BeanDefinitionRegistry中取出加工后的BeanDefinition,并调用InstantiationStrategy着手进行Bean实例化的工作;
5.在实例化Bean时,Spring容器使用BeanWrapper对Bean进行封装,BeanWrapper提供了很多以Java反射机制操作Bean的方法,它将结合该Bean的BeanDefinition以及容器中属性编辑器,完成Bean属性的设置工作;
6.利用容器中注册的Bean后处理器(实现BeanPostProcessor接口的Bean)对已经完成属性设置工作的Bean进行后续加工,直接装配出一个准备就绪的Bean。
Spring容器确实堪称一部设计精密的机器,其内部拥有众多的组件和装置。Spring的高明之处在于,它使用众多接口描绘出了所有装置的蓝图,构建好Spring的骨架,继而通过继承体系层层推演,不断丰富,最终让Spring成为有血有肉的完整的框架。所以查看Spring框架的源码时,有两条清晰可见的脉络:
1)接口层描述了容器的重要组件及组件间的协作关系;
2)继承体系逐步实现组件的各项功能。
接口层清晰地勾勒出Spring框架的高层功能,框架脉络呼之欲出。有了接口层抽象的描述后,不但Spring自己可以提供具体的实现,任何第三方组织也可以提供不同实现, 可以说Spring完善的接口层使框架的扩展性得到了很好的保证。纵向继承体系的逐步扩展,分步骤地实现框架的功能,这种实现方案保证了框架功能不会堆积在某些类的身上,造成过重的代码逻辑负载,框架的复杂度被完美地分解开了。
Spring组件按其所承担的角色可以划分为两类:
1)物料组件:Resource、BeanDefinition、PropertyEditor以及最终的Bean等,它们是加工流程中被加工、被消费的组件,就像流水线上被加工的物料;
2)加工设备组件:ResourceLoader、BeanDefinitionReader、BeanFactoryPostProcessor、InstantiationStrategy以及BeanWrapper等组件像是流水线上不同环节的加工设备,对物料组件进行加工处理。
我们在第3章中已经介绍了Resource和ResourceLoader这两个组件。在本章中,我们将对其他的组件进行讲解。

出处:http://blog.csdn.net//xujar/archive/2008/10/31/3193975.aspx
参考技术A 5.String str = "yes" if (str == "no") str += "ok" 一共创建了几个对象
个人认为有四个对象,不知对还是错
String str = "yes"声明第一个对象
if (str == "no") 创建一个“no”对象
str += "ok" 创建一个新对象str和一个"ok"对象
可以参考
咬文嚼字之String、StringBuffer、StringBuilder性能分析(六)
http://www.diyjava.com/jcrm/ShowArticle.asp?ArticleID=6197

8.Hibernate中解决n+1次查询的方法
答案可以参考进行解答
http://www.diyjava.com/kyjs/ShowArticle.asp?ArticleID=6284

参考资料:http://www.diyjava.com

本回答被提问者采纳
参考技术B 5。我只知道这题的答案,创建了0个对象。因为“YES”是从string池中拿的。不需要创建。 参考技术C 这个面试题想回答全面不容易哦

Java常用API面试题Java面试题

1、Math.round(11.5)等于多少?Math.round(- 11.5) 又等于多少?

public class Test 
    public static void main(String[] args) 
        System.out.println("Math.round(11.5)="+Math.round(11.5));
        System.out.println("Math.round(-11.5)="+Math.round(-11.5));
    

Math.round(11.5)的返回值是12,Math.round(-11.5)的返回值是-11。四舍五入的原理是在参数上加0.5然后进行取整。

2、switch是否能作用在byte 上,是否能作用在long上,是否能作用在String上?

Java5以前switch(expression)中,
expression只能是byte、short、char、int,严格意义上来讲Java5以前只支持int,之所以能使用byte short char是因为存在自动类型转换。

从 Java 5 开始,Java中引入了枚举类型,expression也可以是 enum 类型。

从 Java 7 开始,expression还可以是字符串(String),但是长整型(long)在目前所有的版本中都是不可以的。










3、数组有没有length()方法?String有没有length()方法?

数组没有length()方法,而是有length属性。


public class Test 
    public static void main(String[] args) 
        int a[] = 12,3,45,6,7,8;
        System.out.println(a.length);
    

String有length()方法。JavaScript 中,获得字符串的长度是通过length属性得到的,这一点容易和Java混淆。

4、String 、StringBuilder 、StringBuffer 的区别?

Java平台提供了两种类型的字符串:String 和 StringBuffer/StringBuilder,它们都可以储存和操作字符串,区别如下:

● String 是只读字符串,也就意味着 String 引用的字符串内容是不能被改变的。初学者可能会有这样的误解:

String str  = “abc”;

str = “bcd”;

如上,字符串 str 明明是可以改变的呀!其实不然,str 仅仅是一个引用对象,它指向一个字符串对象“abc”。

第二行代码的含义是让 str 重新指向了一个新的字符串“bcd”对象,而“abc”对象并没有任何改变,只不过对象”abc”已经没有引用指向它了。

● StringBuffer/StringBuilder 表示的字符串对象可以直接进行修改。

● StringBuilder是Java5中引入的,它和StringBuffer的方法完全相同,区别在于它是在单线程环境下使用的,因为它的所有方法都没有被 synchronized 修饰,因此它的效率理论上也比 StringBuffer要高。

5、请说出下面程序的输出?

class Test 
    public static void main(String[] args) 
        String s1 = "Programming";
        String s2 = new String("Programming");
        String s3 = "Program";
        String s4 = "ming";
        String s5 = "Program" + "ming";
        String s6 = s3 + s4;
        System.out.println(s1 == s2);    //false
        System.out.println(s1 == s5);    //true
        System.out.println(s1 == s6);    //false
        System.out.println(s1 == s6.intern());    //true
        System.out.println(s2 == s2.intern());    //false
    

补充:解答上面的面试题需要知道如下两个知识点:

● String 对象的 intern()方法会得到字符串对象在常量池中对应的版本的引用(如果常量池中有一个字符串与String 对象的 equals 结果是 true),如果常量池中没有对应的字符串,则该字符串将被添加到常量池中,然后返回常量池中字符串的引用;

● 字符串的+操作其本质是创建了 StringBuilder 对象进行 append 操作,然后将拼接后的 StringBuilder 对象用 toString 方法处理成 String 对象,这一点可以用 javap -c StringEqualTest.class 命令获得 class 文件对应的 JVM 字节码指令就可以看出来。

6、如何取得年月日、小时分钟秒?

import java.time.LocalDateTime;
import java.util.Calendar;

class DateTimeTest 
    public static void main(String[] args) 
        Calendar cal = Calendar.getInstance();
        System.out.println(cal.get(Calendar.YEAR));//年
        System.out.println(cal.get(Calendar.MONTH)); //月 0 - 11
        System.out.println(cal.get(Calendar.DATE));//日
        System.out.println(cal.get(Calendar.HOUR_OF_DAY));//小时
        System.out.println(cal.get(Calendar.MINUTE));//分钟
        System.out.println(cal.get(Calendar.SECOND));//秒
        // Java 8
        LocalDateTime dt = LocalDateTime.now();
        System.out.println(dt.getYear());//年
        System.out.println(dt.getMonthValue()); //月 1 - 12
        System.out.println(dt.getDayOfMonth());//日
        System.out.println(dt.getHour());//小时
        System.out.println(dt.getMinute());//分钟
        System.out.println(dt.getSecond());//秒
    

7、如何取得从 1970 年 1 月 1 日 0 时 0 分 0 秒到现在的毫秒数?

class GetTime 
    public static void main(String[] args) 
        System.out.println("第一种:" + Calendar.getInstance().getTimeInMillis());
        System.out.println("第二种:" + System.currentTimeMillis());
        System.out.println("第三种:" + Clock.systemDefaultZone().millis());
    

8、如何取得某月的最后一天?

class GetLastDay 
    public static void main(String[] args) 
        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
        //获取当前月第一天:
        Calendar c = Calendar.getInstance();
        c.add(Calendar.MONTH, 0);
        c.set(Calendar.DAY_OF_MONTH, 1);//设置为 1 号,当前日期既为本月第一天
        String first = format.format(c.getTime());
        System.out.println("first:" + first);
        //获取当前月最后一天
        Calendar ca = Calendar.getInstance();
        ca.set(Calendar.DAY_OF_MONTH, ca.getActualMaximum(Calendar.DAY_OF_MONTH));
        String last = format.format(ca.getTime());
        System.out.println("last:" + last);
        //Java 8
        LocalDate today = LocalDate.now();
        //本月的第一天
        LocalDate firstday = LocalDate.of(today.getYear(), today.getMonth(), 1);
        //本月的最后一天
        LocalDate lastDay = today.with(TemporalAdjusters.lastDayOfMonth());
        System.out.println("本月的第一天" + firstday);
        System.out.println("本月的最后一天" + lastDay);

    

运行结果:

9、如何格式化日期?

java.text.DataFormat的子类(如 SimpleDateFormat 类)中的 format(Date)方法可将日期格式化。Java 8 中可以用 java.time.format.DateTimeFormatter 来格式化时间日期,代码如下所示:

import java.text.SimpleDateFormat;
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
import java.util.Date;

class DateFormatTest 
    public static void main(String[] args) 
        SimpleDateFormat oldFormatter = new SimpleDateFormat("yyyy/MM/dd");
        Date date1 = new Date();
        System.out.println(oldFormatter.format(date1));
        // Java 8
        DateTimeFormatter newFormatter = DateTimeFormatter.ofPattern("yyyy/MM/dd");
        LocalDate date2 = LocalDate.now();
        System.out.println(date2.format(newFormatter));
    

运行结果:

补充:Java 的时间日期 API 一直以来都是被诟病的东西,为了解决这一问题,
Java 8 中引入了新的时间日期 API,
其中包括 LocalDate、LocalTime、LocalDateTime、Clock、Instant 等类,
这些的类的设计都使用了不变模式,因此是线程安全的设计。

10、打印昨天的当前时刻?

import java.util.Calendar;

class YesterdayCurrent 
    public static void main(String[] args) 
        Calendar cal = Calendar.getInstance();
        cal.add(Calendar.DATE, -1);
        System.out.println(cal.getTime());
    

//java-8
import java.time.LocalDateTime;

class YesterdayCurrent 
    public static void main(String[] args) 
        LocalDateTime today = LocalDateTime.now();
        LocalDateTime yesterday = today.minusDays(1);
        System.out.println(yesterday);
    

11、JSR310 规范 Joda-Time 的区别?

其实 JSR310 的规范领导者 Stephen Colebourne,同时也是 Joda-Time 的创建者,JSR310 是在 Joda-Time 的基础上建立的,参考了绝大部分的 API,但并不是说 JSR310=JODA-Time,下面几个比较明显的区别是:

● 最明显的变化就是包名(从 org.joda.time 以及 java.time)

● JSR310 不接受 NULL 值,Joda-Time 视 NULL 值为 0

● JSR310 的计算机相关的时间(Instant)和与人类相关的时间(DateTime)之间的差别变得更明显

● JSR310 所有抛出的异常都是 DateTimeException 的子类。虽然 DateTimeException 是一个RuntimeException。


以上是关于急求java面试题的主要内容,如果未能解决你的问题,请参考以下文章

JAVA面试题合集 JAVA面试题

2020年1-6月份Java面试题总结,20多类1100道面试题含答案解析

Java面试题,Java面试题及答案,2021最新的,都整理好了

2020 年最新版 Java 面试题大全(文末附参考答案)

2020年最新版Java面试题大全(文末附参考答案)

java面试题