我是图片

牛客网日常刷题


摘要: 日常

每日五题(第11期)

每周一到周五下午5点半更新,记得持续关注我哦!

1、下列语句正确的是:

A、形式参数可被字段修饰符修饰

B、形式参数不可以是对象

C、形式参数为方法被调用时真正被传递的参数

D、形式参数可被视为local variable

分析:

这题我们首先来讲解一下每个选项的答案,然后再对其知识点进行深度解析。

A、形式参数只能够被final修饰

B、形式参数可以是对象

C、形式参数只是实际参数的拷贝。

D、local variable的意思是局部变量,很显然形参是的。

了解了几个选项后,我们来看下Java中修饰符相关知识

Java中修饰符分为访问权限修饰符和非访问权限修饰符

其中访问权限修饰符有

public:共有访问。对所有的类都可见。

protected:保护型访问。对同一个包可见,对不同的包的子类可见。

default:默认访问权限。只对同一个包可见,注意对不同的包的子类不可见。

private:私有访问。只对同一个类可见,其余都不见。

非访问权限修饰符有:

static 修饰符,用来创建类方法和类变量。

final 修饰符,用来修饰类、方法和变量,final 修饰的类不能够被继承,修饰的方法不能被继承类重新定义,修饰的变量为常量,是不可修改的。

abstract 修饰符,用来创建抽象类和抽象方法。

synchronized 用于多线程的同步。

volatile 修饰的成员变量在每次被线程访问时,都强制从共享内存中重新读取该成员变量的值。而且,当成员变量发生变化时,会强制线程将变化值回写到共享内存。这样在任何时刻,两个不同的线程总是看到某个成员变量的同一个值。

transient:序列化的对象包含被 transient 修饰的实例变量时,java 虚拟机(JVM)跳过该特定的变量。

外部类修饰符

public(访问控制符),将一个类声明为公共类,它可以被任何对象访问,一个程序的主类必须是公共类。

default(访问控制符),类只对包内可见,包外不可见。

abstract(非访问控制符),将一个类声明为抽象类,抽象类不能用来实例化对象,声明抽象类的唯一目的是为了将来对该类进行扩充,抽象类可以包含抽象方法和非抽象方法。

final(非访问控制符),将一个类生命为最终(即非继承类),表示它不能被其他类继承。

注意:

  1. protected 和 private 不能修饰外部类,是因为外部类放在包中,只有两种可能,包可见和包不可见。

  2. final 和 abstract不能同时修饰外部类,因为该类要么能被继承要么不能被继承,二者只能选其一。

  3. 不能用static修饰类,因为类加载后才会加载静态成员变量。所以不能用static修饰类和接口,因为类还没加载,无法使用static关键字。

内部类修饰符

内部类与成员变量地位一致,所以可以public,protected、default和private,同时还可以用static修饰,表示嵌套内部类,不用实例化外部类,即可调用。

方法修饰符

public(公共控制符),包外包内都可以调用该方法。

protected(保护访问控制符)指定该方法可以被它的类和子类进行访问。具体细节可参考:http://blog.csdn.net/dawn_after_dark/article/details/74453915

default(默认权限),指定该方法只对同包可见,对不同包(含不同包的子类)不可见。

private(私有控制符)指定此方法只能有自己类等方法访问,其他的类不能访问(包括子类),非常严格的控制。

final ,指定方法已完备,不能再进行继承扩充。

static,指定不需要实例化就可以激活的一个方法,即在内存中只有一份,通过类名即可调用。

synchronize,同步修饰符,在多个线程中,该修饰符用于在运行前,对它所属的方法加锁,以防止其他线程的访问,运行结束后解锁。

native,本地修饰符。指定此方法的方法体是用其他语言在程序外部编写的。

abstract ,抽象方法是一种没有任何实现的方法,该方法的的具体实现由子类提供。抽象方法不能被声明成 final 和 static。 任何继承抽象类的子类必须实现父类的所有抽象方法,除非该子类也是抽象类。 如果一个类包含若干个抽象方法,那么该类必须声明为抽象类。抽象类可以不包含抽象方法。 抽象方法的声明以分号结尾,例如:public abstract sample();。

成员变量修饰符

public(公共访问控制符),指定该变量为公共的,它可以被任何对象的方法访问。

protected(保护访问控制符)指定该变量可以别被自己的类和子类访问。在子类中可以覆盖此变量。

default(默认权限),指定该变量只对同包可见,对不同包(含不同包的子类)不可见。

private(私有访问控制符)指定该变量只允许自己的类的方法访问,其他任何类(包括子类)中的方法均不能访问。

final,最终修饰符,指定此变量的值不能变。

static(静态修饰符)指定变量被所有对象共享,即所有实例都可以使用该变量。变量属于这个类。

transient(过度修饰符)指定该变量是系统保留,暂无特别作用的临时性变量。不持久化。

volatile(易失修饰符)指定该变量可以同时被几个线程控制和修改,保证两个不同的线程总是看到某个成员变量的同一个值。

final 和 static 经常一起使用来创建常量。

局部变量修饰符

only final is permitted。

为什么不能赋予权限修饰符?

因为局部变量的生命周期为一个方法的调用期间,所以没必要为其设置权限访问字段,既然你都能访问到这个方法,所以就没必要再为其方法内变量赋予访问权限,因为该变量在方法调用期间已经被加载进了虚拟机栈,换句话说就是肯定能被当前线程访问到,所以设置没意义。

为什么不能用static修饰 ?

我们都知道静态变量在方法之前先加载的,所以如果在方法内设置静态变量,可想而知,方法都没加载,你能加载成功方法内的静态变量?

接口修饰符

接口修饰符只能用public、default和abstract。

不能用final、static修饰。

接口默认修饰为abstract。

接口中方法修饰符

only public & abstract are permitted 。

意思只能用 public abstract修饰,当然如果你什么都不写,默认就是public abstract。

注意:在Java1.8之后,接口允许定义static 静态方法了!所以也可以用static来修饰!

本题答案:D

2、以下说法错误的是()

A、虚拟机中没有泛型,只有普通类和普通方法

B、所有泛型类的类型参数在编译时都会被擦除

C、创建泛型对象时请指明类型,让编译器尽早的做参数检查

D、泛型的类型擦除机制意味着不能在运行时动态获取List中T的实际类型

分析:

1、创建泛型对象的时候,一定要指出类型变量T的具体类型。争取让编译器检查出错误,而不是留给JVM运行的时候抛出类不匹配的异常。

2、JVM如何理解泛型概念 —— 类型擦除。事实上,JVM并不知道泛型,所有的泛型在编译阶段就已经被处理成了普通类和方法。 处理方法很简单,我们叫做类型变量T的擦除(erased) 。

总结:泛型代码与JVM

① 虚拟机中没有泛型,只有普通类和方法。

② 在编译阶段,所有泛型类的类型参数都会被Object或者它们的限定边界来替换。(类型擦除)

③ 在继承泛型类型的时候,桥方法的合成是为了避免类型变量擦除所带来的多态灾难。 无论我们如何定义一个泛型类型,相应的都会有一个原始类型被自动提供。原始类型的名字就是擦除类型参数的泛型类型的名字。

本题答案:D

3、下列关于包(package)的描述,正确的是()

A、包(package)是Java中描述操作系统对多个源代码文件组织的一种方式。

B、import语句将所对应的Java源文件拷贝到此处执行。

C、包(package)是Eclipse组织Java项目特有的一种方式。

D、定义在同一个包(package)内的类可以不经过import而直接相互使用。

分析:

1、为了更好地组织类,Java提供了包机制。包是类的容器,用于分隔类名空间。如果没有指定包名,所有的示例都属于一个默认的无名包。Java中的包一般均包含相关的类,java是跨平台的,所以java中的包和操作系统没有任何关系,java的包是用来组织文件的一种虚拟文件系统。A错

2、import语句并没有将对应的java源文件拷贝到此处仅仅是引入,告诉编译器有使用外部文件,编译的时候要去读取这个外部文件。B错

3、Java提供的包机制与IDE没有关系。C错

4、定义在同一个包(package)内的类可以不经过import而直接相互使用。

本题答案:D

4、给出以下代码,请给出结果.

class Two{
    Byte x;
}
class PassO{
    public static void main(String[] args){
        PassO p=new PassO();
        p.start();
    }
    void start(){
        Two t=new Two();
        System.out.print(t.x+””);
        Two t2=fix(t);
        System.out.print(t.x+” ” +t2.x);
    }
    Two fix(Two tt){
        tt.x=42;
        return tt;
    }
}

A、null null 42

B、null 42 42

C、0 0 42

D、0 42 42

E、An exception is thrown at runtime

F、Compilation

分析:

一图搞定

本题答案:B

5、下面有关 java 类加载器,说法正确的是?()

A、引导类加载器(bootstrap class loader):它用来加载 Java 的核心库,是用原生代码来实现的

B、扩展类加载器(extensions class loader):它用来加载 Java 的扩展库。

C、系统类加载器(system class loader):它根据 Java 应用的类路径(CLASSPATH)来加载 Java 类

D、tomcat 为每个 App 创建一个 Loader,里面保存着此 WebApp 的 ClassLoader。需要加载 WebApp 下的类时,就取出 ClassLoader 来使用

分析:

1)Bootstrap ClassLoader

负责加载$JAVA_HOME中jre/lib/rt.jar里所有的class,由C++实现,不是ClassLoader子类

2)Extension ClassLoader

负责加载java平台中扩展功能的一些jar包,包括$JAVA_HOME中jre/lib/*.jar或-Djava.ext.dirs指定目录下的jar包

3)App ClassLoader

负责记载classpath中指定的jar包及目录中class

4)Custom ClassLoader

属于应用程序根据自身需要自定义的ClassLoader,如tomcat、jboss都会根据j2ee规范自行实现ClassLoader

加载过程中会先检查类是否被已加载,检查顺序是自底向上,从Custom ClassLoader到BootStrap ClassLoader逐层检查,只要某个classloader已加载就视为已加载此类,保证此类只所有ClassLoader加载一次。而加载的顺序是自顶向下,也就是由上层来逐层尝试加载此类。

关于D选项,详情可看这篇文章https://www.cnblogs.com/aspirant/p/8991830.html

本题答案:ABCD

链接:https://www.nowcoder.com/questionTerminal/99bfa10e4c1e429e98856bca6d80586e 来源:牛客网

点赞
1
赞赏


  • 作者:kuls
  • 简介:一个热爱编程的小伙子!
  • 版权:转载文章需找站长授权,未经授权转载,必会追究!
二维码

评论

留言