牛客刷题 2020年9月11日
-
关于Java语言中的final关键字的使用,下列说法正确的是()
正确答案: C 你的答案: B (错误)
在使用final关键字定义的方法里面使用final关键字定义变量。 使用final关键字定义变量,必须在变量定义的同时给定变量的具体数值,完成变量初始化。 final关键字可以用来修饰方法,表明此方法不可以被子类重写。 使用final关键字定义变量,必须同时使用static关键字。 解释: A 选项在 final 定义的方法里,不是必须要用 final 定义变量。 B final 定义的变量,可以在不是必须要在定义的同时完成初始化,也可以在构造方法中完成初始化。 C 正确,final修饰方法,不能被子类重写,但是可以被重载。 D final 定义变量,可以用 static 也可以不用。 只针对B选项: 在定义的时候可以给定指定值,比如private final int b =1; 或者使用构造方法完成初始化,可以在idea中尝试。
-
java程序内存泄露的最直接表现是( )
正确答案: C 你的答案: A (错误)
频繁FullGc jvm崩溃 程序抛内存控制的Exception java进程异常消失 解释: java是自动管理内存的,通常情况下程序运行到稳定状态,内存大小也达到一个 基本稳定的值 但是内存泄露导致Gc不能回收泄露的垃圾,内存不断变大. 最终超出内存界限,抛出OutOfMemoryExpection
-
下列有关Servlet的生命周期,说法不正确的是?
正确答案: A 你的答案: D (错误)
在创建自己的Servlet时候,应该在初始化方法init()方法中创建Servlet实例 在Servlet生命周期的服务阶段,执行service()方法,根据用户请求的方法,执行相应的doGet()或是doPost()方法 在销毁阶段,执行destroy()方法后会释放Servlet 占用的资源 destroy()方法仅执行一次,即在服务器停止且卸载Servlet时执行该方法 解释: 创建Servlet的实例是由Servlet容器来完成的,且创建Servlet实例是在初始化方法init()之前 Servlet的生命周期分为5个阶段:加载、创建、初始化、处理客户请求、卸载。 (1)加载:容器通过类加载器使用servlet类对应的文件加载servlet (2)创建:通过调用servlet构造函数创建一个servlet对象 (3)初始化:调用init方法初始化 (4)处理客户请求:每当有一个客户请求,容器会创建一个线程来处理客户请求 (5)卸载:调用destroy方法让servlet自己释放其占用的资源
-
下面有关JAVA异常类的描述,说法错误的是?
正确答案: D 你的答案: B (错误)
异常的继承结构:基类为Throwable,Error和Exception继承Throwable,RuntimeException和IOException等继承Exception 非RuntimeException一般是外部错误(非Error),其必须被 try{}catch语句块所捕获 Error类体系描述了Java运行系统中的内部错误以及资源耗尽的情形,Error不需要捕捉 RuntimeException体系包括错误的类型转换、数组越界访问和试图访问空指针等等,必须被 try{}catch语句块所捕获 解释: 异常是指程序运行时(非编译)所发生的非正常情况或错误,当程序违反了语音规则,jvm就会将出现的错误表示一个异常抛出。 异常也是java 的对象,定义了基类 java。lang。throwable作为异常父类。 这些异常类又包括error和exception。两大类 error类异常主要是运行时逻辑错误导致,一个正确程序中是不应该出现error的。当出现error一般jvm会终止。 exception表示可恢复异常,包括检查异常和运行时异常。 检查异常是最常见异常比如 io异常sql异常,都发生在编译阶段。这类通过try、catch捕捉 而运行时异常,编译器没有强制对其进行捕捉和处理。一般都会把异常向上抛出,直到遇到处理代码位置,若没有处理块就会抛到最上层,多线程用thread。run()抛出,单线程用main()抛出。常见的运行异常包括 空指针异常 类型转换异常 数组月结异常 数组存储异常 缓冲区溢出异常 算术异常等,
-
下面有关java的引用类型,说法正确的有?
正确答案: A B C D 你的答案: A B C D (正确)
对于一个对象来说,只要有强引用的存在,它就会一直存在于内存中 如果一个对象仅持有虚引用,那么它就和没有任何引用一样,在任何时候都可能被垃圾回收器回收。 如果一个对象只具有软引用,则内存空间足够,垃圾回收器就不会回收它;如果内存空间不足了,就会回收这些对象的内存 一旦发现了只具有弱引用的对象,不管当前内存空间足够与否,都会回收它的空间 解释: 一,强引用 Object obj = new Object(); //只要obj还指向Object对象,Object对象就不会被回收 obj = null; //手动置null 只要强引用存在,垃圾回收器将永远不会回收被引用的对象,哪怕内存不足时,JVM也会直接抛出OutOfMemoryError,不会去回收。如果想中断强引用与对象之间的联系,可以显示的将强引用赋值为null,这样一来,JVM就可以适时的回收对象了 二,软引用 软引用是用来描述一些非必需但仍有用的对象。在内存足够的时候,软引用对象不会被回收,只有在内存不足时,系统则会回收软引用对象,如果回收了软引用对象之后仍然没有足够的内存,才会抛出内存溢出异常。这种特性常常被用来实现缓存技术,比如网页缓存,图片缓存等。 在 JDK1.2 之后,用java.lang.ref.SoftReference类来表示软引用。 三,弱引用 弱引用的引用强度比软引用要更弱一些,无论内存是否足够,只要 JVM 开始进行垃圾回收,那些被弱引用关联的对象都会被回收。在 JDK1.2 之后,用 java.lang.ref.WeakReference 来表示弱引用。 四,虚引用 虚引用是最弱的一种引用关系,如果一个对象仅持有虚引用,那么它就和没有任何引用一样,它随时可能会被回收,在 JDK1.2 之后,用 PhantomReference 类来表示,通过查看这个类的源码,发现它只有一个构造函数和一个 get() 方法,而且它的 get() 方法仅仅是返回一个null,也就是说将永远无法通过虚引用来获取对象,虚引用必须要和 ReferenceQueue 引用队列一起使用。
-
Java程序的种类有( )
正确答案: B C D 你的答案: A C (错误)
类(Class) Applet Application Servlet Java程序的种类有: (a)内嵌于Web文件中,由浏览器来观看的_Applet (b)可独立运行的 Application (c)服务器端的 Servlets