A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

wudimj

初级黑马

  • 黑马币:20

  • 帖子:7

  • 精华:0

1、byte常量池面试题
          Integer i1 = new Integer(127);
          Integer i2 = new Integer(127);
          System.out.println(i1 == i2);  // false
          System.out.println(i1.equals(i2));  // true

          System.out.println("--------");

          Integer i3 = new Integer(128);
          Integer i4 = new Integer(128);
          System.out.println(i3 == i4);  // false
          System.out.println(i3.equals(i4)); // true
      

          Integer i5 = 128;
          Integer i6 = 128;
          System.out.println(i5 == i6);  // false
          System.out.println(i5.equals(i6)); // true

          System.out.println("--------");

          Integer i7 = 127;
          Integer i8 = 127;

          System.out.println(i7 == i8); // true
          System.out.println(i7.equals(i8)); // true

          结论:byte范围内的值(-128 ~ 127),java提供了一个常量池。直接赋值给Integer,是从常量池里面获取的。

2、String类面试题
          1.     
          public static void main(String[] args) {
               String s = "abc";
               change(s);
               System.out.println(s);
          }
          public static void change(String s) {
               s += "hello";
          }
          注:基本类型 -- 形式参数改变不影响实际参数。
               引用类型 -- 形式参数改变直接影响实际参数。
               但是,字符串是特殊的引用类型,实参传递到形参时,实际上是把值传递给了形参。
         
          -- 如果是StringBuffer.则打印的是abchello。StringBuffer容量可变。
         


          2. 字符串拼接问题
          public static void main(String[] args) {
               String s1 = "a";
               String s2 = "b";
               String s3 = "ab";
               System.out.println(s3 == s1 + s2); // false
               System.out.println(s3 == "a" + "b"); // true,常量的运算会在编译期间就计算,所以"a"+"b"在编译后就是"ab"
          }
          注:JVM对于字符串引用,由于在字符串的"+"连接中,有字符串引用存在,而引用的值在程序编译期是无法确定的。
               JVM对于字符串常量的"+"号连接,在程序编译期,JVM就将常量字符串的"+"连接优化为连接后的值。

Exception 下为 可查异常和runtimeException两大类~

可查异常是由于环境造成`是捕获处理的重点` 可以恢复的

runtimeException~是由于你程序设计的有漏洞`比如 1/0~的情况~ 正确设计不会出现的` 一般不捕获或处理~

main()方法throws出异常会有jvm 处理~ 其实就是jvm终止你线程~


方法中的内部类能不能访问方法中的局部变量,为什么?
* @author
* 答:方法中的内部类不能直接访问方法中的局部变量;
* 原因:内部类的生命周期和方法中的局部变量是不一样的,内部类是也是一个类,是存储在堆中,也只有当对该类的引用消失时,内部类才会消亡。
*        而方法的局部变量是存储在堆栈中的,当调用结束时就会弹栈,就是在内存中这个属性就消失了。
*        内部类的生命周期超过了方法中局部变量的生命周期,内部类可能会调用到已经消失的属性,因此内部类不能直接访问方法中的局部变量。
* 解决方法:局部变量前加修饰符final,此时局部变量就会存在堆中,生命周期和内部类的生命周期是一样的,此时内部类就可以访问方法中的局部变量。



A:面试题
        一个类如果没有抽象方法,可不可以定义为抽象类?如果可以,有什么意义?

        abstract class A{
                show(){
               
                }

                method(){
               
                }
        }
        


        class B {
                //1.无法new
                private B(){}


                //2.如何获取对象?  
                public static B getInstance(){
                        return  new B();
                }
        }

        class Test{
                main(){
                B b = B.getInstance();
                }
        }

B:面试题
        abstract 不能和哪些关键字共存?


        
        private    冲突 -- 对子类隐藏,而 abstract 必须让子类重写
        final      冲突 -- 不能被重写,矛盾
        static     无意义-- 类名调用,没有方法体,无意义


        public static

        public static final

        方法前面  public

        属性前面  private
*/

class {

        public static void main(String[] args){

                System.out.println();
        }
}

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马