Java学习之面试题整理

(面试题)Java基本数据类型和引用数据类型(2019年10月8日)

1,java 基本数据类型有几种?哪几种?(面试题)
     答:8种 byte short int long float double char boolean

2,int类型是几个字节?(面试题)
     答:4字节

3, int i = 3000000000; 编译能通过吗?原因是什么?(面试题)
     答:不能 右边数据是int类型但超出了int类型的表示范围 大约20多亿(-2^31--2^31-1)

4,3默认是什么类型?3.14默认是什么类型?(面试题)
     答:3默认int类型 3.14默认double类型

5,请问H的字符值(ASCII值)是多少?(面试题)

     答:(A:65   a:97)

6,为什么 int a = 09;会报错
     答:因为在进制表示中0开头的表示八进制,而八进制中不能出现大于7的数!

7,int a=3&4;请问a的值为多少

     答:在java中,如果&前后都是数字,那么表示位运算符,按位与:先把十进制的数转化成为二进制,然后按位与,都为1的时候才是1,其余都为0

            同理可知  在java中也是位运算符,按位或:先把十进制的数转化成为二进制,然后按位与,都为0的时候才是0,其余都为1

8,高类型向低类型转换需要强制转换吗?强制转换可能导致什么问题?
     答:需要 可能导致精度丢失或溢出

9,String是基本数据类型吗?(面试题)

     答:不是,是引用数据类型

10, int i=2;  int b = i++ + ++i + i++ ;    b等于多少?i等于多少?(面试题)

     答:计算过程:第一个 i++        i先使用   再自增    2+ ++i + i++    此时 i=3

                              到第二个 ++i     i先自增   再使用    2+4 + i++       此时 i=4

                              到第三个i++     i先使用   再自增     2+4+4            此时 i=5

                            一般可由有多少个  i++  或  ++i  直接确定  i  的值   ,每出现一次直接加1

(面试题)循环语句(2019年10月10号)

1,下面程序运行的结果是什么?(面试题)

1 int i = 1 ;
2 while(i<=20){
3     i++;
4     i=i++ ;
5     System.out.println(" char长度为1,用单引号括起来。 ");
6 }
7 System.out.println(i);

     答:程序陷入死循环   右边的运算结果为1 ,i永远都是1

(面试题)二维数组和方法(2019年10月11日)

1,打印星星

 1 //定义五行
 2 int hs = 5;
 3 for (int i = 1; i <= hs; i++) {
 4 // 打印空格
 5 for (int j = 1; j <= hs - i; j++) {
 6 System.out.print(" ");
 7 }
 8 // 打印*号
 9 for (int j = 1; j <= i + i - 1; j++) {
10 System.out.print("*");
11 }
12 System.out.print("
");
13 }

2,冒泡排序(面试题)

有一个数组{7,5,14,23,19,2,4},要求使用冒泡进行排序(从大到小)

 1  public static void main(String[] args){
 2          int [] arr={7,5,14,23,19,2,4};
 3          //比较轮数
 4          for(int i=1;i<arr.length-1;i++){
 5                //从左往右,两两相比
 6                for(int j=1;j<arr.length-1;j++){
 7                     //交换
 8                     if(arr[j]<arr[j+1]){
 9                         int temp=arr[j+1];
10                         arr[j+1]=arr[j];
11                         arr[j]=temp;
12                     }
13                }
14          }
15  } 

3,内存分配原理  (面试题)

  

 

(面试题)面相对象(2019年10月14日)

1,谈谈你对面向对象的理解?什么是类跟对象?(面试题)

      答:面向对象是向现实世界模型的自然延伸,这是一种“万物皆对象”的编程思想。   类是对象的抽象 对象是类的具体实例。

               面向对象有三大特性,封装、继承和多态。

            封装就是将一类事物的属性和行为抽象成一个类,使其属性私有化,行为公开化,提高了数据的隐秘性的同时,使代码模块化。这样做使得代码的复用性更高。

            继承则是进一步将一类事物共有的属性和行为抽象成一个父类,而每一个子类是一个特殊的父类--有父类的行为和属性,也有自己特有的行为和属性。

            这样做扩展了已存在的代码块,进一步提高了代码的复用性。

            如果说封装和继承是为了使代码重用,那么多态则是为了实现接口重用。多态的一大作用就是为了解耦--为了解除父子类继承的耦合度。

           (这是主观题,不要死记,通过自己理解,然后可以在网上找一些答案,将和自己理解相近的记下来)

         

1,final的用法?(面试题)

     答:1,当final修饰变量的时候,表示常量,内容不可以更改。
            2,当修饰类的时候表示这个类不能够被继承。
            3,当修饰方法的时候表示这个方法不能被覆写。

2,重载跟重写有什么区别?(面试题)

     答:重写:子类与父类方法名相同,参数列表必须完全与被重写的方法相同,返回类型必须一直与被重写的方法相同,访问修饰符的限制一定要大于等于被重写方法的访问修饰符,重写最多一次。
            重载:子类与父类方法名相同,必须具有不同的参数列表, 可以有不同的返回类型,可以有不同的访问修饰符,重载可以N次

3,java的3大特性是什么?

     答:封装   继承   多态

(面试题)抽象类和静态属性以及静态方法(2019年10月17日)

1,抽象类是否一定有抽象方法?

     答:不一定,但有抽象方法的类一定是抽象类

2,堆跟栈有什么区别?

     答:1,最主要的区别就是栈内存用来存储局部变量和方法调用;而堆内存用来存储Java中的对象。无论是成员变量,局部变量,还是类变量,它们指向的对象都存储在堆内存中。

            2,栈空间比较小;堆空间比较大。

3,说下有哪几种访问修饰符?他们有什么区别?(面试题)

     答:public   protected    default(不写)   private    权限由高到低

            private :只有同类可以直接访问

            default(不写):同类,同包可以直接访问

            protected:同类,同包和子类可以直接访问

            public:同类,同包,子类和不同包的类都可以直接访问

4,java内存结构分为哪几部分?(面试题)

      答:栈,堆,方法区,程序计数器,本地方法栈(native)

5,构建对象会经历哪些步骤?(面试题)

       答:1,访问方法区看类是否已经被加载,如果没有先加载(静态成员会在第一次加载时初始化)

              2,然后通过关键字new在堆中申请空间,初始化对象

              3,执行方法里面的逻辑

6,静态方法中可以调用非静态的变量吗?非静态的方法中可以调用静态的变量吗?(面试题)

     答:静态方法不可以调用非静态的变量,非静态方法可以调用静态的变量

(面试题)String,Random,Math 等一些Object对象(2019年10月22日)

1.请列举switch case中可以填写的类型

答:byte  short  int char  String enum

2.请判断下面生成了几个对象

        String a="dax";
        String b= new String("dax");

 答:产生两个对象,一个在堆内存中 还有一个在方法区中的常量池中

3.请判断下面输出结果

     String str6 = "b";  
        String str7 = "a" + str6;  
        String str67 = "ab";  
        System.out.println("str7 = str67 : "+ (str7 == str67)); 

答:结果是false,因为系统编译的时候不知道str6是一个变量,系统不会自动帮你完成字符串的拼接

3.请判断下面输出结果

     final String str2 = "ab"; 
        final String str3 = "cd";
        String str4 = str2+str3;  //
        String str5 = "abcd"; 
        System.out.println("str4 = str5 : " + (str4==str5));

答:输出的结果是true,由于里面都是字符串常量,结果可以在编译期间就确定下来,所以在class中已经是str1 = "abcd"

(面试题)ArrayList,HashSet以及HashMap(2019年10月23日)

1,看如下代码会输出什么

1 Integer i1 = 120 ;
2 Integer i2 = 120 ;
3 Integer i3 = new Integer(120);
4 Integer i4 = new Integer(120);

    答: Integer 在类加载的时候会先在静态区中初始化好-128 127 之间的数值,如果在这个范围则直接重复使用,否则在堆中new一个Integer

              120:true 由于10在范围内,所以使用共用静态区中的Integer

              1000:false 由于1000在范围外,所以在堆中重新new一个Integer

2,ArrayList可以有重复的元素吗?元素是有序的吗?

    答:有重复的元素,元素是有序的

3,ArrayList和Vector有什么区别

 答:ArrayList是线程不安全的,效率高

    Vector是线程安全的,效率低

4,有23个对象加入到HashSet中,初始化最小为多少

 答:23/0.75=30.66...<32=2^5

    所以初始化32个最好,又不会扩容。也不会浪费空间

5,写一个迭代器

1 // 迭代器遍历
2 Iterator<String> iterator = set.iterator();
3 while(iterator.hasNext()){
4 System.out.println(iterator.next()); 
5 }

 6,List 跟Set   Map的区别?

     答:List:继承Collection接口,有序集合,允许重复元素。

            Set: 继承Collection接口,无序集合,不允许重复元素,且最多有一个null值。

            Map: Map是独立接口,key_value键值对存储数据;不允许重复元素。

7,Vector 跟ArrayList的区别是什么?

     答:ArrayList线程不安全,效率高 ,扩容1.5倍;Vector 线程安全,效率低,扩容2倍。

8,说下java中的集合,说下ArrayList底层原理?
      答:  对于ArrayList而言,它实现List接口、底层使用数组保存所有元素。其操作基本上是对数组的操作。
                  ArrayList定义只定义类两个私有属性:elementData存储ArrayList内的元素,size表示它包含的元素的数量

9,说下ArrayList跟LinkList的区别?

     答:Arraylist:底层是基于动态数组,动态数组就是改变数组容量方法,创建新的数组,指定新的容量(原来的1.5倍),将旧数组复制到新数组中并本类旧数组指向新数组 

            LinkedList:LinkedList的实现是基于双向链表,并实现队列(Queue),双向队列(Deque)接口     

               对于随机访问:ArrayList优于LinkedList             对于插入和删除操作:LinkedList优于ArrayList

            LinkedList比ArrayList更占内存,因为LinkedList的节点除了存储数据,还存储了两个引用,一个指向前一个元素,一个指向后一个元素。

(面试题)异常处理(2019年10月25日)

1,final  finally  finalize有什么区别?

   答:final修饰变量表示其不能改变,修饰方法表示其不能重写,修饰类表示其不能被继承

          finalize当垃圾回收器回收时执行其中的逻辑

          finally无论是否发生异常,最终都会执行其中的逻辑

2,throws  throw 区别是什么?

   答:throws:用来声明一个方法可能产生的所有异常,不做任何处理而是将异常往上传,谁调用我我就抛给谁。

          throw:则是用来抛出一个具体的异常类型。

3,写出5个常见异常?(面试题)

   答:数组越界异常 (ArrayIndexOutOfBoundsException )

          空指针异常   (NullPointException)

          类转换异常  (ClassCastException)

          算术异常    (ArithmeticException)

          类不存在异常 (ClassNotFoundException)

 待补充。。。。。

    

原文地址:https://www.cnblogs.com/sunzhiqiang/p/11641059.html