美文网首页
JAVA面试题集合

JAVA面试题集合

作者: 前度天下 | 来源:发表于2020-06-09 10:16 被阅读0次

1、JAVA中int占用几个字节?

int是占用4个字节、也就是32位bit。范围就是-2的32次方到2的32次方减1。
扩展:什么是字节:字节他是衡量计算机数据容量的一个单位。一个字节包含了8位的二进制数。字符串分为英文和中文。英文它是延续ASCII码的1个字节,就可以表示英文字母。中文根据不同的编码占用 的这个字节就不一样。GBK占用2个字节,UTF-8是占用2/3或4个字节。

2、java面向对象的特征

  • 封装:就是把实体的一些数据和操作方法集合到一起就是封装。封装的思想是为了避免外部直接操作数据,降低对内部数据的一个影响,提高程序的安全性和可维护性。只能通过规定的方法去访问操作数据,隐藏了实现内部的一个细节。
  • 继承:子类继承父类的一些数据和方法。具有父类的某些数据和方法。共有了一些方法,不需要子类再去自己写一系列的方法了,坏处就是子类他依赖父类,缺乏独立性,不支持动态继承,不能改变父类的接口。
  • 多态:同一个引用类型,使用不同的实例而执行不同操作,具体的体现就是父类的引用指向了子类的实例。好处就是提高代码的可维护性和可扩展性。弊端就是不能使用子类的特有功能。

3、装箱和拆箱&有了基本的数据类型为什么还需要包装类型?

基本类型(8大基本类型)

  • 整型:byte(1B)、short(2B)、int(4B),long(8B)
  • 浮点型:float(4B),double(8B)
  • 布尔型:boolean(1B),
  • 字符型:char(2B)
    String不是基本的数据类型
    每个基本的数据类型都会有一个对应得包装类(int---Integer)
    装箱,基本数据类项转换成对应的包装类型
    拆箱,包装类转基本数据类型
    答案:java面向对象是面向对象的语言,而基本的数据类型不具备面向对象的特性(封装继承多态)

4、==和equals的区别

首先 == 是用来比较两个变量所指向的内存地址是否相同,可以用来两个基本类型的数据或两个引用变量是否相等。
在Object类中: equals方法的实现是 return this==obj , 也就是说equals与 == 是一样的,比较的都是两个对象所指向的内存地址是否相同。但是在String类中重写了父类Obejct中的equls方法,比较的是两个对象的内容是否相同。

5、String&StringBuilder&StringBuffer

String是一个引用数据类型。final的,不可被继承。不可变的Unicode字符序列。本质上为char 字符数组。
StringBuilder和StringBuffer都是继承抽象类AbstractStringBuilder。StringBuffer实现的方法都是有Synchronized。所以StringBuffer是支持多线程操作是线程安全的,速度相对于StringBuilder慢一些。
StringBuilder 不支持并发操作,非线程安全;但速度更优。

6、讲一下java中的集合

— List 有序,可重复

ArrayList
优点: 底层数据结构是数组,查询快,增删慢。
缺点: 线程不安全,效率高
Vector
优点: 底层数据结构是数组,查询快,增删慢。
缺点: 线程安全,效率低
LinkedList
优点: 底层数据结构是链表,查询慢,增删快。
缺点: 线程不安全,效率高
—Set 无序,唯一

HashSet
底层数据结构是哈希表。(无序,唯一)
如何来保证元素唯一性?
1.依赖两个方法:hashCode()和equals()

LinkedHashSet
底层数据结构是链表和哈希表。(FIFO插入有序,唯一)
1.由链表保证元素有序
2.由哈希表保证元素唯一

TreeSet
底层数据结构是红黑树。(唯一,有序)
1. 如何保证元素排序的呢?
自然排序
比较器排序
2.如何保证元素唯一性的呢?
根据比较的返回值是否是0来决定

Map接口有三个比较重要的实现类,分别是HashMap、TreeMap和HashTable。

TreeMap是有序的,HashMap和HashTable是无序的。
Hashtable的方法是同步的,HashMap的方法不是同步的。这是两者最主要的区别。
这就意味着:

Hashtable是线程安全的,HashMap不是线程安全的。
HashMap效率较高,Hashtable效率较低。
如果对同步性或与遗留代码的兼容性没有任何要求,建议使用HashMap。 查看Hashtable的源代码就可以发现,除构造函数外,Hashtable的所有 public 方法声明中都有 synchronized关键字,而HashMap的源码中则没有。
Hashtable不允许null值,HashMap允许null值(key和value都允许)
父类不同:Hashtable的父类是Dictionary,HashMap的父类是AbstractMap

相关文章

  • Java基础面试总结

    【面试汇总】Java面试题-1Java面试题-2 【集合】Java集合及concurrent并发包总结(转)Jav...

  • Collection

    参考地址:Java集合常见面试题集锦Java集合必会14问(精选面试题整理) Java中Collection和Co...

  • Java面试题目录

    垃圾回收 面试题-Java基础-垃圾回收 java垃圾回收 集合 40个Java集合面试问题和答案 Java集合框...

  • Java面试题目录

    垃圾回收 面试题-Java基础-垃圾回收 java垃圾回收 集合 40个Java集合面试问题和答案 Java集合框...

  • Java集合框架面试题

    标签(空格分隔): Java集合框架 面试题汇总 1. 什么是Java集合框架?请列举出集合(Collection...

  • Java面试题收集

    (长期更新)此贴用来收集Java相关的面试题集合 115个Java面试题和答案——终极列表(上) 115个Java...

  • 面试总结-Java高级篇

    Java面试总结 1.你用过哪些集合类? 大公司最喜欢问的Java集合类面试题 40个Java集合面试问题和答案 ...

  • 一、面试总结(一)

    1.你用过哪些集合类? 大公司最喜欢问的Java集合类面试题40个Java集合面试问题和答案java.util.C...

  • 集合相关

    Java面试题 1.Java集合框架是什么?说出一些集合框架的优点? 集合框架的部分优点如下: 使用核心集合框类降...

  • Java面试题

    Java面试题 Java 集合源码分析 https://www.cnblogs.com/joemsu/p/7667...

网友评论

      本文标题:JAVA面试题集合

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