美文网首页Java面试篇大数据技术
Java大数据面试常见问题

Java大数据面试常见问题

作者: 北京大数据苏焕之 | 来源:发表于2018-08-12 14:59 被阅读295次

    Java大数据面试常见问题

    1.String 和StringBuffer的区别

    JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据这个String类提供了数值不可改变字符串而这个StringBuffer类提供的字符串进行修改当你知道字符数据要改变的时候你就可以使用StringBuffer典型地,你可以使用StringBuffers来动态构造字符数据

    2.说出ArrayList,Vector, LinkedList的存储性能和特性

     ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized思路方法(线程安全) ,通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项前后项即可,所以插入速度较快
    

    3.HashMap和Hashtable的区别

    HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,主要区别在于HashMap允许空(null)键值(key),由于非线程安全,效率上可能高于HashtableJAVA中文站社区门户oC)| g| a�x ,HashMap允许将Null作为一个entryde key 或者value,而Hashtable不允许 HashMap把Hashtable的contains思路方法去掉了,改成containsvalue和containsKey因为contains思路方法容易让人引起误解Hashtable继承自Dictionary类,而HashMap是Java1.2引进的Map interface的一个实现。
    最大的区别是,Hashtable的思路方法是Synchronize的,而HashMap不是,在多个线程访问Hashtable时,不需要自己为它的思路方法实现同步,而HashMap 就必须为的提供外同步。
    Hashtable和HashMap采用的hash/rehash算法都大概一样,所以性能不会有很大的差异。

    1. final, finally, finalize的区别

    final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。
    finally是异常处理语句结构的一部分,表示总是执行。
    finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾收集时的其他资源回收,例如关闭文件等。

    1. swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
      swtich中只能用byte short int char

    2. 多线程有几种实现方法,都是什么?哪一种方式比较优秀?同步有几种实现方法,都是什么?
      多线程有两种实现方法,分别是继承Thread类与实现Runnable接口
      实现Runnable接口比较好,因为实现类可以实现多个接口,而只能继承一个类。
      同步的实现方面有两种,分别是synchronized,wait与notify

    3. java中有几种类型的流?JDK为每种类型的流提供了一些抽象类以供继承,请说出他们分别是哪些类

    字节流,字符流。字节流继承与inputStream/outputStream,字符流继承于inputStreamReader/outputSteamWriter。

    8:如果main方法被声明为private会怎样?

    答案:能正常编译,但运行的时候会提示”main方法不是public的”。

    9:Java里的传引用和传值的区别是什么?

    答案:传引用是指传递的是地址而不是值本身,传值则是传递值的一份拷贝。

    10:如果要重写一个对象的equals方法,还要考虑什么?

    答案:hashCode。
    11:Java的”一次编写,处处运行”是如何实现的?

    答案:Java程序会被编译成字节码组成的class文件,这些字节码可以运行在任何平台,因此Java是平台独立的。

    12:说明一下public static void main(String args[])这段声明里每个关键字的作用

    答案:public: main方法是Java程序运行时调用的第一个方法,因此它必须对Java环境可见。所以可见性设置为pulic.
    static: Java平台调用这个方法时不会创建这个类的一个实例,因此这个方法必须声明为static。
    void: main方法没有返回值。
    String是命令行传进参数的类型,args是指命令行传进的字符串数组。

    13:==与equals的区别

    答案:==比较两个对象在内存里是不是同一个对象,就是说在内存里的存储位置一致。两个String对象存储的值是一样的,但有可能在内存里存储在不同的地方 .
    ==比较的是引用而equals方法比较的是内容。public boolean equals(Object obj) 这个方法是由Object对象提供的,可以由子类进行重写。默认的实现只有当对象和自身进行比较时才会返回true,这个时候和==是等价的。String, BitSet, Date, 和File都对equals方法进行了重写,对两个String对象 而言,值相等意味着它们包含同样的字符序列。对于基本类型的包装类来说,值相等意味着对应的基本类型的值一样。
    public class EqualsTest {
    public static void main(String[] args) {
    String s1 = “abc”;
    String s2 = s1;
    String s5 = “abc”;
    String s3 = new String(”abc”);
    String s4 = new String(”abc”);
    System.out.println(”== comparison : ” + (s1 == s5));
    System.out.println(”== comparison : ” + (s1 == s2));
    System.out.println(”Using equals method : ” + s1.equals(s2));
    System.out.println(”== comparison : ” + s3 == s4);
    System.out.println(”Using equals method : ” + s3.equals(s4));
    }
    }
    结果:
    == comparison : true
    == comparison : true
    Using equals method : true
    false
    Using equals method :true

    14:如果去掉了main方法的static修饰符会怎样?

    答案:程序能正常编译。运行时会抛NoSuchMethodError异常。

    15:为什么oracle type4驱动被称作瘦驱动?

    答案:oracle提供了一个type 4 JDBC驱动,被称为瘦驱动。这个驱动包含了一个oracle自己完全用Java实现的一个TCP/IP的Net8的实现,因此它是平台独立的,可以在运行时由浏览器下载,不依赖任何客户端 的oracle实现。客户端连接字符串用的是TCP/IP的地址端口,而不是数据库名的tnsname。

    16:介绍一下finalize方法

    答案: final: 常量声明。 finally: 处理异常。 finalize: 帮助进行垃圾回收。
    接口里声明的变量默认是final的。final类无法继承,也就是没有子类。这么做是出于基础类型的安全考虑,比如String和Integer。这样也使得编译器进行一些优化,更容易保证线程的安全性。final方法无法重写。final变量的值不能改变。finalize()方法在一个对象被销毁和回收前会被调用。finally,通常用于异常处理,不管有没有异常被抛出都会执行到。比如,关闭连接通常放到finally块中完成。

    17:什么是Java API?

    答案:Java API是大量软件组件的集合,它们提供了大量有用的功能,比如GUI组件。

    18:GregorianCalendar类是什么东西?

    答案:GregorianCalendar提供了西方传统日历的支持。

    19:ResourceBundle类是什么?

    答案:ResourceBundle用来存储指定语言环境的资源,应用程序可以根据运行时的语言环境来加载这些资源,从而提供不同语言的展示。

    20:为什么Java里没有全局变量?

    答案:全局变量是全局可见的,Java不支持全局可见的变量,因为:全局变量破坏了引用透明性原则。全局变量导致了命名空间的冲突。

    21:如何将String类型转化成Number类型?

    答案:Integer类的valueOf方法可以将String转成Number。下面是代码示例:
    String numString = “1000″;
    int id=Integer.valueOf(numString).intValue();

    22:SimpleTimeZone类是什么?

    答案:SimpleTimeZone提供公历日期支持。

    23:while循环和do循环有什么不同?

    答案:while结构在循环的开始判断下一个迭代是否应该继续。do/while结构在循环的结尾来判断是否将继续下一轮迭代。do结构至少会执行一次循环体。

    24:Locale类是什么?

    答案:Locale类用来根据语言环境来动态调整程序的输出。
    25:面向对象编程的原则是什么?
    答案:主要有三点,多态,继承和封装。

    相关文章

      网友评论

        本文标题:Java大数据面试常见问题

        本文链接:https://www.haomeiwen.com/subject/fepsbftx.html