• java----牛客练习


    一、下面代码的输出结果是什么?

    public class ZeroTest {
        public static void main(String[] args) {
         try{
           int i = 100 / 0;
           System.out.print(i);
      }catch(Exception e){
           System.out.print(1);
           throw new RuntimeException();
      }finally{
           System.out.print(2);
      }
          System.out.print(3);
     }
     }
    分析:
    1、inti = 100/ 0; 会出现异常,会抛出异常,System.out.print(i)不会执行,
    2、catch捕捉异常,继续执行System.out.print(1);
    3、当执行 thrownewRuntimeException();  又会抛出异常,这时,除了会执行finally中的代码,其他地方的代码都不会执行
    4.  还是需要理解Try...catch...finally与直接throw的区别:try catch是直接处理,处理完成之后程序继续往下执行,throw则是将异常抛给它的上一级处理,程序便不往下执行了。本题的catch语句块里面,打印完1之后,又抛出了一个RuntimeException,程序并没有处理它,而是直接抛出,因此执行完finally语句块之后,程序终止了
    5.
    首先执行try,遇到算术异常,抛出,执行catch,打印1,然后抛出RuntimeException,缓存异常,执行finally,打印2,然后抛出RuntimeException。
    如果catch中没有抛出RuntimeException,则执行结果为123。
    二、在Java中,以下关于方法重载和方法重写描述正确的是?
    目前的问题:父类的功能无法满足子类的需求。
     
    方法重写的前提: 必须要存在继承的关系。
     
    方法的重写: 子父类出了同名的函数,这个我们就称作为方法的重写。
     
    什么是时候要使用方法的重写:父类的功能无法满足子类的需求时。
     
    方法重写要注意的事项:
        1.方法重写时, 方法名与形参列表必须一致。
        2.方法重写时,子类的权限修饰符必须要大于或者等于父类的权限修饰符。
        3.方法重写时,子类的返回值类型必须要小于或者 等于父类的返回值类型。
        4.方法重写时, 子类抛出的异常类型要小于或者等于父类抛出的异常类型。
                Exception(最坏)
                RuntimeException(小坏)
     
    方法的重载:在一个类中 存在两个或者两个 以上的同名函数,称作为方法重载。
     
    方法重载的要求
        1. 函数名要一致。
        2. 形参列表不一致(形参的个数或形参 的类型不一致)
        3. 与返回值类型无关。
    三、
    方法的重写(override)两同两小一大原则
    方法名相同,参数类型相同
    子类返回类型小于等于父类方法返回类型,
    子类抛出异常小于等于父类方法抛出异常,
    子类访问权限大于等于父类方法访问权限。
    四、
    public class Niuke_java {
    
        public static boolean isAdmin(String userId)
        {
            return userId.toLowerCase() =="admin";
        }
        public static void main(String[] args) {
            // TODO Auto-generated method stub
            System.out.println(isAdmin("Admin"));
        }
    
    }       //  答案返回false

    equals和==的区别 ==操作比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量在堆中存储的地址是否相同,即栈中的内容是否相同。

    ==是判断地址,string的tolowercase很明显是拿着原有的字符串又new了个地象,所以地址不一样。

    五、

    class Foo {
        final int i;
        int j;
        public void doSomething() {
            System.out.println(++j + i);
        }
    }//不能执行,因为编译有错
    
    
    final作为对象成员存在时,必须初始化;但是,如果不初始化,也可以在类的构造函数中初始
     
    因为java允许将数据成员声明为final,却不赋初值。但是,blank finals必须在使用之前初始化,且必须在构造函数中初始化。
    final修饰的变量是常量,必须进行初始化,可以显示初始化,也可以通过构造进行初始化,如果不初始化编译会报错。
    六、
    A. StringBuffer类调用toString()方法后将转换为String类型   正确 
    B. String类型中没有append()方法,要追加字符串”+“即可,也没有必要 append 
    C. 可以直接将字符串“test”复制给声明的Stirng类的变量,而StringBuffer类的不行 
    D. String 实例 是不可变的
    String 对象/实例 是不可以被改变的。

    当new一个String对象时,JVM会在内存中创建一个String对象,当另外一个String对象值与它一样时,会将该对象直接指向对应的地址。

  • 相关阅读:
    Hadoopif.for.while 语句
    完全分布模式的四大模块设置
    语法糖定义
    Karaf 依赖equinox and felix,karaf 本Apache的很多项目作为基础框架
    Karaf 基于 osgi
    MEF(Managed Extensibility Framework) 微软平台插件化开发
    析构函数,构造函数
    C#和ASP.Net面试题目集锦
    论C# java的基本类型
    Boolean.parseBoolean("true") 和 Boolean.getBoolean("true");的区别及用法
  • 原文地址:https://www.cnblogs.com/simplepaul/p/6505678.html
Copyright © 2020-2023  润新知