java基础2 }+ U# W$ o F. s
- 简述Java的基本历史
+ C a. c* g1 u& b
java起源于SUN公司的一个GREEN的项目,其原先目的是:为家用消费电子产品发送一个信息的分布式代码系统,通过发送信息控制电视机、冰箱等 ; M: u0 l4 c Y" a0 B6 G( {* d) Y
- 简单写出Java特点,写出5个以上,越多越好0 a1 n) x% @1 L0 k% K9 S1 r/ e2 M
简单的、面向对象的、分布式的、安全的、稳定的、与平台无关的、可解释的、多线的、动态的语言。 + t# G8 Z& ^6 m' e# P+ S# Y
- 什么是Java?
# i( c" B5 J3 Q8 r
JAVA:一种编程语言 一种开发环境 一种应用环境 一种部署环境
) j3 h: z2 m8 Z& g% l8 [" b2 [- 请写出Java的版本分类,以及每种版本的应用方向+ m0 T% @0 x) O2 j
三种版本: JME:是面向内存有限的移动终端. 为消费性产品设计的; JSE: 是SUN公司针对桌面开发和低端商务计算方案开发的版本。为笔记本电脑、PC机设计的; JEE: 是一种利用JAVA 2平台来简化企业解决方案的开发、部署和管理相关的复杂问题的体系结构。 为企业级的、服务器端的高端应用而设计的; $ [- i4 g) ?& d e2 c4 g! z) G' i. \
- 描述Java技术的主要特性
) r0 C4 ^# h" N' j7 [/ a% b
java虚拟机 垃圾回收 代码安全性 3 m0 D% b3 C4 ]/ V& ^- I0 t
- 描述 Java虚拟机的功能% F" `' Q# ~7 ^+ O7 C" f/ ?, e0 I
(1)通过 ClassLoader 寻找和装载 class 文件 (2)解释字节码成为指令并执行,提供 class 文件的运行环境 (3)进行运行期间垃圾回收 (4)提供与硬件交互的平台
) a* `4 n. p+ {8 w- 简述Java代码安全性
& Z4 S& K* [; L' H+ I" W3 `& M
(1)编译时的错误检验 (2)类装载检查,把本机上的类和网络资源类相分离,在调入类的时候进行检查,因而可以限制任何“特洛伊木马“的应用! \. Y2 }/ F6 s$ S0 x5 |
(3)字节码校验 (4)沙箱机制,限定访问权限 / ^. F( ?4 H" z/ P ?; ` e) c
- 描述Java垃圾回收机制. M# n @4 @" }
Java 编程语言解除了程序员释放内存的责任。它可提供一种系统级线程以跟踪每一次内存的分配情况。在 Java 虚拟机的空闲周期,垃圾收集线程检查并释放那些可被释放的内存。垃圾收集在 Java 技术程序的生命周期中自动进行,它解除了释放内存的要求,这样能够有效避免内存漏洞和内存泄露(内存泄露就是程序运行期间,所占用的内存一直往上涨, 很容易造成系统资源耗尽而降低性能或崩溃 。
" X! h& Y; O0 F. z 垃圾回收有以下特点:& G$ e/ `0 q" [: B- {
(1)垃圾回收是一个自动的系统行为,程序员不能控制垃圾回收的功能和行为。) A* ? b- I: U$ a, J
(2)有一些跟垃圾回收相关的方法,比如:System.gc( ) ,调用这些方法,仅仅是在通知垃圾回收程序,至于垃圾回收程序运不运行,什么时候运行,都是无法控制的。6 ?- Z% V8 H, _. [; Y5 L4 Q- S
(3)程序员可以通过设置对象为 null,来标示某个对象不再被需要了, 这只是表示这个对象可以被回收了,并不是马上被回收。0 a/ b1 `. _/ H& S Q/ }& b
+ g* | z$ t7 n; R
- 简述Java代码的运行过程
$ c+ B/ l) V' L# D9 q3 ]
(1)加载代码 通过类装载器装载CLASS文件 (2)校验代码 由字节码校验 (3)执行代码 由解释器将字节码转换成机器码
+ q5 L4 ^! f& d! e/ |) q1 Z
3 z9 p, G1 ], ?7 z- 简述如何搭建Java开发环境+ A2 ~( M% G3 y8 t, a. e @
首先下载安装JDK 然后配置环境 (1)配置PATH, (2)配置CLASSPATH (3)配置JAVA_HOME : ?" h5 D" i& s
- 简述classpath,path,JAVA_HOME的意义和配置方法
( \# W# K# L$ r$ k6 R% d& \
path 操作系统运行环境的路径 classpath JAVA运行应用程序时所需要的类包的路径 JAVA_HOME 供需要运行JAVA的程序使用 ; x& A% m v% o. Z- J8 w
- 请描述:一个完整的Java文件的代码分几个部分,每部分都起什么作用,大致的写法
( a, s% ?# z6 O& {# n$ l& Z8 s
package 当前类所在位置 import 当前类运行时所需要的包或类 public class 类名 { 属性定义; 方法定义: 构造方法定义; public static void main(String args []) 例外{ 程序入口 语句; } } //注释 ) }# P* V c8 D% s+ p' [
- Java代码的注释有几种?分别举例说明3 a) A8 y3 j+ Q3 k: t8 E K
(1) // 单行注解 (2) /* */ 块注释 (3) /* * * 文档注释 */
" t( X; g0 ]# L# ?# O8 r/ Y- 什么是Java代码的语句,什么是Java代码的块,举例说明
) j- e2 _5 G# i4 ^
语句 是一行以分号终止的代码,例:int a; 块 是以{ }为边界的一些语句的集合 例:public void tt( ){} ' {+ u: B. b6 J
- 什么是标示符?+ y: G8 P( Q% R3 S2 c$ Q( z5 `
标识符:是赋予变量、类、方法的名称。$ ?4 G" @6 z7 I4 F
$ r% k& C4 b# v; r: `7 `- 标示符定义的规则?
1 H% o( }0 A% v* v- 首字母只能以字母、下划线、$开头,其后可以跟字母’下划线、$和数字配置CLASSPATH
- 首字母小写中间用大写字母隔开
- 标识符具有一定的含义5 Q @# i) Z2 Y( `2 o
- 什么是关键字?
/ X4 }2 N3 s0 O7 ?. y( r, x1 R关键字就是编程语言与机器语言的编码约定
" X9 j0 A9 k7 N* `+ I/ J; A
3 P9 p c: U0 v- true、false、null、sizeof、goto、const那些是Java关键字; A5 k: ^; @$ k
true 、false 、null 为JAVA的关键字 - Java的基本数据类型有几种?分别是?
) l; a3 [7 [! H7 D* K7 q: nshort int long boolean float double char byte W X o* Z0 g! d: B$ T
7 u' \2 ]1 u: j6 M* r p- B& Q
- 请写出每种基本类型的默认值?取值范围?分别给出一个定义的例子6 j" z: N* {4 ? ?4 H, L$ _9 Q: S
默认值 取值范围 示例 $ D" ]. B3 Q; I* a
字节型 : 0 -2^7—-2^7-1 byte b=10; 字符型 : ‘ ′ 0—-2^16-1 char c=’c’ ; short : 0 -2^15—-2^15-1 short s=10; int : 0 -2^31—-2^31-1 int i=10; long : 0 -2^63—-2^63-1 long o=10L; float : 0.0f -2^31—-2^31-1 float f=10.0F double : 0.0d -2^63—-2^63-1 double d=10.0; boolean: false truealse boolean flag=true;
$ [+ ]. f" T6 V$ t& H/ @4 N: y- 在基本类型中,如果不明确指定,整数型的默认是什么类型?带小数的默认是什么类型?" p6 X# z/ x+ J" G+ w) |' s1 b
整数类型 默认为 int 带小数的默认为 double
3 S& z8 X0 T# w0 A# ~- 如何定义float类型和long型
, {" e) F7 \5 K7 O2 t+ c( K
float f = 1.2f long l = 1.2L
8 R( k1 O3 T! a+ L6 w3 e- 什么是变量?
! @% \# ?1 w* q+ f x, e+ f" U: V2 I
变量是用来引用一块内存区域或一个值,用标识符来表示,可以通过操作变量来操作变量所对应的内存区域或值块的值。 / z8 a8 n# r; ^, _" b
- 变量的定义规则?
# A7 F8 O, z) I7 p0 H$ f; ]- 以字母、$、下划线开头,其后可以跟字母、下划线、$和数字;
- 首字母小写,中间单词用大写字母隔开;
- 名称具有一定含义;
: j5 I R) d5 s- B, s; S X
- e6 p9 [ d, f$ k& ]9 O- 请写出Java编码约定中对下列部分的要求:类、属性、方法、包、文件名、变量、常量、控制结构、语句行、注释
8 d ]0 T9 R/ F) T j7 n
类: 一个类文件中类名要和文件名相同,类名一定要以大写字母开头,单词之间用大写字母分隔 属性: 属性名首字母小写,中间用大写字母隔开。 方法: 方法名首字母小写,中间用大写字母隔开。 包: 引用包必须写在类文件的开头,有且只能有一个包,全部用小写字母。 控制结构:当语句是控制结构的一部分时,即使是单个语句,也应使用大括号将语句封闭。 语句行:每行只写一个语句,并使用四个缩进的空格,使代码更易读,注意用分号结束。 注释: 用注释来说明那些不明显代码的段落。 常量: 常量名一般用大写字母,单词之间用下划线分隔,一旦赋值不允许修改。
$ f# r2 u& p4 B5 [0 L- 什么是Javadoc?
4 }! R9 s) @5 j6 [! f) d1 V# f9 b
按照一定格式生成程序的文档的工具。
8 C3 w# @% E' T: U9 d) o3 d \- 什么是引用类型?4 K7 H. ?" A% i/ c D) c( D
用户定义类型, 它可引用类和数组。
4 F" U3 s9 Y1 O; T
除去基本数据类型的其他类型都是引用数据类型。 - 什么是按值传递?什么是按引用传递? u0 u$ _5 W i2 K4 I
按值传递:就是将该值的副本传过去(基本数据类型+String类型的传递,就是按值传递) 按引用传递:就是将值的内存地址传过去(除基本数据类型+String以外类型的传递,就是引用传递)
( D7 O7 T9 r( t6 d. U" h- 如何创建一个新对象?如何使用对象中的属性和方法?) s$ k. ^; I% |
使用new 关键字来创建一个新的对象; 通过对象的实例用”.“(点)来调用对象中的属性和方法; 静态的方法和属性,也可以直接用类名”.“(点)来调用; . U( C5 Z: C6 `, Q, w4 Z/ U) F7 ?
- 简述new关键字所做的工作
' a+ \: t4 d; z. Rnew 创建一个对象,并为对象分配一块内存。8 k3 Q& K9 j* W' q h" n6 `
. m/ O! B7 k1 z3 a( s( w: {- 简述”=” 和”= =”的功能和区别
* a* B& w6 p; D! d# M3 j7 [4 h, A
“=” 赋值, “= =”当比较基本数据类型的时候,判断前后两个值是否相等; 当比较引用数据类型的时候,判断= =前后两个值的内存地址是否相等; 区别: = :为赋值表达式 = = :为逻辑表达式 % a( X3 X5 b! V/ W7 L
- 什么是实例变量?什么是局部变量?什么是类变量?什么是final变量?
N2 t- G m6 m/ V( s$ V7 D3 \
实例变量: 类中定义的变量,即类成员变量,如果没有初始化,会有默认值; 局部变量: 在方法中定义的变量,必须初始化; 类变量: 用static修饰的属性; final变量: 用final 修饰的变量, . w0 R$ Y% Y! g; A
- 简述上述各种变量的定义规则和使用规则?
5 A/ H. Z7 L5 t
实例变量: 不需要static关键字来声明,需要类的实例(对象)调用(用”.“); 类变量: 用static修饰,可以用类名调用,也可以用类的实例调用; 局部变量: 在方法内任意定义变量即为局部变量; final变量: 一旦赋值,不可以再修改的变量; final属性只允许赋值一次,且只能通过构造方法赋值,定义后也就是一个常量; final修饰的变量,只允许赋值一次
8 F/ h( F, Z, n% K! A" h8 X5 x- a++和++a的区别?
) [% [: d8 V; S, i# i- T
a++ : 先使用,后加1 ++a : 先加1,后使用 9 L7 P4 g; c; A$ V& F
? : 三目运算符: 表达式1?表达式2:表达式3 如果表达式1为true,执行表达式2,否则执行表达式3 &: 位运算:按位与 | &&: 逻辑运算:逻辑与
1 L) B( Q- y- P7 Q4 o0 E9 h- 请描述>>、<<、>>>的功能9 ?0 [9 |6 I( X1 P7 g
10>>4 :算术或符号右移位运算符 << :算术或符号左移位运算符 >>> :逻辑或无符号右移位运算符 ! @2 v+ t5 Q( C' u# i
- 请描述什么是强制类型转换?什么是自动类型转换?什么是向上造型?并分别举例说明
. S3 A4 h2 F1 j* _- J' N强制类型转换:在一个类型前面加( ),来强制转换
5 ^2 }, }1 R5 V f1 H% S9 Z- Q' w
long l = 9L; int i = (int)l; 自动类型转换: int i = 5; String str = “”+i; 向上造型:把范围小的造型为范围大的类型: int i = 2; long l = i;
: f- L4 t) s* u; ^0 e" X, q b4 `- 请写出完整的if条件控制语句的结构4 f' J2 B9 J+ b6 ?: Q: m
if(布尔表达式){ 语句 }else{ 语句 } 2 a( Q1 r5 \3 _7 a5 ?
- 请写出完整的switch语句的结构
5 U/ ?- [7 i) ^4 [! P2 kswitch(字符){
9 W1 E) b" |, _8 Q$ B
case 字符: 语句 break; case 字符: 语句 break; default:语句 } ; |7 `& d1 {1 |, [8 S7 `2 f
- 请写出完整的for语句的结构' `6 M5 [1 a M6 X' C6 J
for(初始语句;条件语句;步长){ }
9 H$ E1 y: b2 C, Y7 X# x) ?- 请写出完整的while语句的结构
1 d1 Z5 L: z M) w
while(boolean语句){ }
* g `9 y4 c3 X/ V3 r, k7 J6 o; L1 M- 请写出完整的do while语句的结构
& x+ e% w9 T3 R+ Y W+ k
do{ }while(boolean语句);
* \, x3 L# k6 j2 q# W- 请描述break 和 continue的功能和用法
j9 f" x! u' d( {9 u
break:终止(跳出)最近的循环 continue:跳出本次循环,执行下一次循环
8 A. E7 ^' \" d3 X% f5 M2 ^- 定义一个一维的int数组,先创建它,并初始化它,给它赋值,然后输出其中的一个值
. O1 R# T9 G1 k4 U9 }5 E
public class Arr{ public static void main(String args[]){ int a[] = new int[5]; a={1,2,3,4,5};//错误 , 只能在初始化时这样做 a[0]=1; a[1]=2; System.out.println(a[0]); } }
6 a2 @* [- z7 i8 i- 定义一个一维的A类型数组,直接定义并赋值,然后输出其中的一个值% V9 y1 @& @ ~. Z( k2 ?& G3 O
public class A{ public static int i; public static void main(String args[]){ A aa = new A( ); A bb = new A( ); A a[] = {aa,bb}; a[0].i=2; System.out.println(a[0]); } } 4 S" ~' V' N& n3 J: l* B
- 把上面的数组改成2维的数组) d3 G n. o0 H' X" y& m3 G2 ^
public class A{ public static int i; public static void main(String args[]){ A a[ ][ ] = new A[5][5]; a[0][0].i=2; System.out.println(a[0][0]); } } : r0 d3 h1 d4 B( G' S! K' b
- 举例说明数组拷贝方法的使用:arraycopy方法) B( I. s, |9 u( B
public class A{ ; w9 b8 S/ y& \) U+ g/ q# s& }3 W
public static void main(String args[]){ int a[] = new int[5]; int b[] = new int[5]; System.arraycopy(a[5],0,b[5],0,a.length) System.out.println(b[0][0]); } } V' q. V: ^" N7 q5 A0 W
- 什么是构造和析构方法?功能是?
3 M% x! `* [. s3 x2 d2 m8 \
构造方法:每个类至少有一个构造方法,类初始化时调用的方法 1.方法名和类名相同 2.无返回值类型 格式:访问权限 类名(参数列表) {}; 1.自己定义构造后,就没有默认的构造方法 2.无构造方法时,默认为空参的构造方法(无参数,方法体为空)7 |& `# T# m8 m8 e
析构方法:finalize 类销毁时,自动调用方法 当对象在内存中被删除时,自动调用该方法 在此方法中可以写回收对象内部的动态空间的代码 ) ^1 e' y: P: D" t4 U! C% Q
- 简述Java的访问修饰符类型?分别有什么功能?
/ S% `0 G# @4 M4 [
public 公开的,任何一个类都有可以访问 protected 同包同类,只可被它的子类访问 default 只能被同一个包中类访问 private 私有的,只能在本类中被访问 ) E3 P4 x L. n9 U; ?
0 a. L6 k, i. a/ [; }+ O7 [
4 h+ g, t3 {) M2 ]# q1 X
2 V. p y* u% ~! `& Q
0 q* y0 Y9 g* i
0 R" Z" L( @7 d& V5 y/ V% Y" w% X; j# y3 C1 s/ |
9 r8 h& S% A, \: d# i4 u
0 _, M; ^2 L$ ?. C' l' U7 a$ s( N1 P, ^7 a- L- I' [: A
- 分别说明:在类上、在属性上、在方法上能使用哪些访问修饰符" K' c2 f/ b* W
在类上:public default final 在方法上: 访问权限:public protected private default 方法修饰符:static final 返回类型:void 在属性上:public protected private default static final # r1 L9 Z' r! ?" A5 ~7 ]/ c
- 简述什么是包?包的功能
* e! {& ^1 }- u4 Y
包:对所定义的多个JAVA类进行分组,将多个功能相关的类定义到一个包(文件)中。 功能:1.易于查找和使用适当的类 2.包不止包含类和接口,还可以包含其它包,形成层次的包空间 3.有助于避免命名冲突
; a: v/ @% h1 x6 E; w- 请写出5个以上的JDK中的包,以及他们的基本功能 z! r! J! T n& ]
java.awt: 包含构成抽象窗口工具集的多个类,用来构建和管理应用程序的图形用户界面 java.lang: 提供java编成语言的程序设计的基础类 java.io: 包含提供多种输出输入功能的类, java.net: 包含执行与网络有关的类,如URL,SCOKET,SEVERSOCKET, java.applet: 包含java小应用程序的类 java.util: 包含一些实用性的类 9 Y) \9 ~$ `/ Z6 T; a- F9 ~
- 什么是包装类?Java中都有哪些包装类
% d. x7 e; j/ y+ a在JDK中针对各种基本类型分别定义相应的引用类型 ————–称为封装类0 ~& s ~3 E3 |' s/ {7 G
Boolean Byte Short Integer Long Float Double Character
4 d# i+ x7 O) }- A1 ]) h- OOP(面向对象)语言的三大特征是?( s2 U. g r8 O" o; H* i- E
封装性,继承性,多态性
a( Y' j% m& J4 k
) h& ]# J: R' t5 |) A2 U- 分别表述类的三大特性及其他们的功能
8 S8 {& P, g/ D; O
封装:隐藏类的实现细节、迫使用户去使用一个接口去访问数据、使代码更好维护 继承:子类可以直接继承使用父类的方法,程序员只需要做的是定义额外特征或规定将适用的变化 多态性:同一个行为具有多个不同表现形式或形态的能力 " N5 i: w0 a/ a( B( f; M) W
- 如何实现继承?继承的规则?. E8 l1 F5 v3 C" a
public class A extends B{ } - 单继承性
- 构造方法不能继承
- super引用父类,调用父类的属性,方法
- 当子类中出现与父类的方法名,返回类型,参数列表相同的方法时要覆盖此方法
4 ]5 g V! |( L- B/ ~
- 简述this和super的功能和用法
5 N# C* a( `' ]6 }7 @
this : - 能访问除构造方法以外所有的属性、方法,通过this. 来调用方法和属性
- 不可以在静态方法中使用,
- 在调用其它构造方法时,必须放在该构造方法的第一行
- 在构造方法中使用this(参数列表),相当于调用本类的其它构造方法,它必须作为构造方法的第一句
# Y: n W+ V \ I1 r / m7 g) z6 n, d0 Q9 J9 K
super :访问父类 - super. 点取父类中被子类隐藏的方法和属性,
- 通过 super(参数列表) 来调用父类的属性和方法,在调用父类的构造方法时必须放在子类构造方法里的第一行;
3 T8 v5 [' v& ^! d3 } , P$ j4 a, g" u2 |$ c" I+ M2 d
- 如何确定在多态的调用中,究竟是调用的那个方法?) t9 s) ]! x. b( K3 X) r
new的是哪一个类就是调用的哪个类的方法。
" m1 H/ Z" t- p4 I2 [+ }) T
/ _2 v4 A. k+ X. @! f* L7 D2 U0 b- 请描述方法定义的完整的语法结构
) O) ]4 Y5 P6 c. [ }7 N# s7 }/ n
权限修饰符 修饰符 返回类型 方法名(参数) 例外{ 方法体; }
# g, c# t/ r- a/ P7 A- 什么是重载?+ n6 r% p/ h5 l- l
在一个类中出现方法名相同,但参数列表不同时,这种情况就是重载。2 z) A' q4 \: `* P8 o4 n2 N
- P3 i) j5 N: t2 k- 简述重载的规则, A2 K: Z. [& A! J1 L7 ~1 t
- 方法名称必须相同;
- 参数列表必须不同(个数不同,或类型不同,或参数排列顺序不同);
- 与返回类型无关;
1 I! {( o" e8 R, f1 e: y
- 什么是方法的覆盖?什么情况下出现?
0 G" N# E2 B5 L6 M3 t
方法覆盖: 子类可以修改从父类继承过来的行为,也就是说子类可以创建一个与父类方法有不同功能的方法,但具有相同的:名称、返回类型名和参数列表。 在父子类的情况下出现时。 % ^5 b1 w3 j6 I1 I
- 方法覆盖的规则?1 G6 b! _; m$ P% O: I+ G" z
- 方法名要和父类中被覆盖的方法名相同,返回类型相同,参数列表相同。
- 访问权限要大于等于被覆盖方法的权限。
- 例外列表要小于等于被覆盖方法的例外列表。
! q" g* c7 i4 n' T+ ~* `
9 u" a4 V) ^* D9 |+ c- static修饰符的功能是?可以用在什么地方?怎么访问?
* O2 y, L r& y* [5 m1 ostatic 修饰符功能:
8 u# B3 L7 v& c1 O3 p' D. M- 共用一块内存区域,也就是用static修饰的变量或成员方法对所有类的实例都是相同的
- 静态成员方法和静态变量的优点在于他们能在没有创建类的任何一个实例的情况下被引用。
- 可以用在方法或属性上1 ~& I* y& z' ]" p- k3 n
访问方式: - 直接使用类名调用
- new 一个实例,用实例调用2 u0 j. _: j2 I; \7 _
4 Q1 T/ b9 R: g; ~- static的基本规则
; B( K+ E" N& R1 b* D+ L- 类中的静态方法只可以调用静态的属性和方法,不允许调用非静态的属性和方法。
- 静态变量为类变量,可以用类名直接调用静态的属性和方法。
- 静态方法中不允许出现this和super
- 构造方法不允许声明static
- 非静态变量为实例变量,通过实例调用
- 静态方法不能被非静态方法覆盖
; m' ]2 s8 Y" Z, [" l8 [8 [
' w w4 I4 @/ ]% z2 l
0 K$ W2 O; `8 W2 z( n
- final修饰符的功能是?可以用在什么地方?
[$ K8 y0 B) h/ N3 W! N$ F, k
功能:final标记所有通用的功能,不能随意更改 可以用在类、属性和方法上
3 Q" ]/ T4 E1 M! q' S+ i- final的基本规则5 ^$ s- u% d7 g) v2 j# y+ l
- final修饰的类不能被继承
- final修饰的成员变量只允许赋值一次,且只能通过构造方法里赋值。
- final修饰的局部变量即为常量,只能赋值一次。
- final修饰的方法不允许被子类覆盖。2 Z7 U- i2 ] G5 B; d
& N. I3 A, A& o r+ G7 m4 Y7 I9 G
6 |# c/ Q r: F8 S: ]
9 Z6 G" m7 K( j1 U1 n! |/ `- 什么是抽象方法,什么是抽象类: k' L \' b( B- T; L2 K/ F9 t
用abstract修饰的方法,只有方法的声明,而没有方法的实现,就叫抽象方法。 用abstract修饰的类,就叫抽象类。
3 j. S2 [$ o4 ?& |6 Y- 抽象类的规则 ]) ]% q# r- w% V# o! }
- 抽象类内部可以没有抽象方法
- 必须用abstract修饰
- 不能够直接使用抽象类,必须通过子类继承并且实现
- 抽象方法不允许被private修饰
" o' q3 K! E+ f" N1 x# e) L
3 D7 p% X: Q( E7 h( h
- 什么情况下使用抽象类
4 w: o4 h. I9 ?" |) w% x) `. L- 当一个类的一个或多个方法是抽象方法时;
- 当类是一个抽象类的子类,并且不能为任何抽象方法提供任何实现细节或方法体时;
- 当一个类实现一个接口,并且不能为任何抽象方法提供实现细节或方法体时;
! m- O5 i+ [8 r
) i" y$ ~: E8 F' x6 d
- equals方法和”= =”的功能和区别
1 K5 P! n W; o7 r, A6 O
功能:判断对象是否相等 区别: equals方法比较的是对象的值 = =:比较的是对象值的内存地址,对基本数据类型来说= =比较的是数值
0 l1 U0 E$ e! K6 t' ?, s; j( Y5 |- toString方法的功能和基本写法
; Z4 i4 B, J# w
返回一个String类型 public String toString(){ return “”; }
' W/ h( B: Y# P$ `) Y' b7 F; J- String的方法的功能和基本使用方法,请描述5个以上
2 ]" _" o; `2 Y
substring(参数1,参数2); 功能:取字符串中参数1到参数2的的所有字符; “String”.subString(0,1); replace(参数1,参数2); 功能:用参数1中的值替换字符串中所有参数2的值 “String”.replace(ing,tt); equals( ); 功能:判断两个字符串是否相等 “String”.equals(“tt”); trim( ); 功能:去掉字符串两边的空格 “String”.trim(); indexof( ); 功能:查找字符串中参数所在位置,并返回字符串第一个出该参数的下标 “String”.indexOf(“ing”); split( ); 功能:根据参数分割该字符串 “String”.split(“-”); 9 C6 H" N- i6 _2 A' U, } J, |
- 为什么使用StringBuffer类?有什么功能和优点?
) @ F7 P! j; {% b; l–只创建一个对象 ; M7 I3 Z/ T( K
–StringBuffer 对象的内容是可以被修改的 –除了字符的长度之外,还有容量的概念 –通过动态改变容量的大小,加速字符管理 ! z0 P$ C( }) K" j4 k
9 Z3 K. K' u9 g7 D' j
- 举例说明如何使用StringBuffer) n& ?( l6 D, P
StringBuffer sb = new StringBuffer(); sb.append(“aaa”); : L5 k- S4 Z1 S, d1 U) G
- 如何使用Java读写系统属性?* L! Q/ `6 ?( C
读:
6 N& a+ Q% [3 v8 g0 C' p( T5 c$ n$ z
Properties props = System.getProperties();
+ D& F | ], C- a3 z H; p Enumeration prop_names = props.propertyNames();
0 T. o8 ]; N5 @8 \/ U# | while (prop_names.hasMoreElements()) {
( r, R/ T4 P- F' n/ Y- B+ { String prop_name = (String) prop_names.nextElement();" c2 E" e) i6 S
String property = props.getProperty(prop_name);/ E: n! L4 \& ]2 A) K
System.out.println(“Property ‘” + prop_name + “‘ is ‘”+ property + “‘”);
! A2 D4 l- O& o% W" q9 d. c } 写: N9 p3 |3 n3 B# K
System.setProperties(props);/ p) V3 g% P) z4 o0 f8 u+ @
$ Y% t+ P- |1 u, j用法: public class Test {, D( |0 U- {0 |7 Y! [8 i0 y
public static void main(String args[]) {) y) k: M- C$ G
try {( O- R v/ J1 H2 \7 y. t& }3 n; H0 N; L
String name = “test.properties”;; T, V2 x# J0 }$ i' B! b4 J
InputStream in = new BufferedInputStream(new FileInputStream(name));4 W, o: Y! P! y9 P
Properties p = new Properties();* G9 V: [/ Q& Q" {+ _
p.load(in);! J6 B/ K$ c' z! r
System.out.println(“a的值==” + p.getProperty(“a”));5 O, f. ^7 X" J M r1 X
} catch (Exception err) {& V2 b+ M g' d3 _: Y0 J: m
err.printStackTrace();
% H4 k( {$ a2 P& c) F% ? }" s8 o; o! y& q& Y' G
}( Y5 m- n7 r" @" y
}
; U K" K/ I) y0 P% A
! l/ Y0 |* G% L2 P- 什么是接口?接口的定义规则?
/ M( i+ |1 _- B, G7 i
接口是抽象方法和常量值的定义的集合。从本质上讲,接口是一种特殊的抽象类,这种抽象类中只包含常量和方法的定义,而没有变量和方法的实现。
$ G* K' V2 l- |3 @# z1 `' }. m y public interface Tt { public void outPut( ); public int tt( ); } / ] g# D" C0 k
- 接口的作用?为什么使用接口?
2 [: k. c7 X1 z4 L% M多重继承
* O* ?: x$ D4 a) |! L( L
封装、隔离 功能,实现的分离 多态 便于后期维护 接口是可插入性的保证。
2 k# w6 R+ X: d' K3 ?# u! ]- 什么是多重接口
4 D& |2 S2 v9 ?就是一个类实现多个接口
$ i0 I! l0 `; ~1 X
! ?1 e$ [; s9 V4 `. G( I/ `$ m- 描述接口的基本思想?7 i9 j+ L0 A6 c3 _: n% h+ I4 {: O
封装 隔离 接口及相关机制的最基本作用在于:通过接口可以实现不相关类的相同行为, 而不需考虑这些类之间的层次关系。 根据接口可以了解对象的交互界面,而不需了解对象所属的类。 面向对象程序设计讲究”提高内聚,降低耦合”。 + n) q @8 w/ }2 M/ W; J5 y
- 如何在代码中使用接口?
9 e6 Y6 r" j+ y- \* ]0 U% x
public class MyCast implements Tt{ public void outPut( ){} public int tt( ){ return 0; } } 8 U7 _, B4 |* X1 s1 _5 A$ l
- 举例说明如何把接口当作类型使用1 N6 V9 b7 \8 N8 h: l) L
public interface Animal(){ public void tt( ); } public class Dog implements Animal{ public void tt ( ){} } " _' ~# i' A, F# ~
Animal ani = new Dog(); A0 p% D+ ?% Z, \7 \; }0 S
- 如何选择接口和抽象类?为什么?6 y \& c$ @" b
优先选用接口,尽量少用抽象类, Z9 a5 B$ m# x* I+ ~
在下列情况下选择抽象类:需要定义子类的行为,又要为子类提供共性的功能。
9 r. F8 e |* c* A; O; ^ + X4 o8 D }" e4 I4 B% O
- 什么是异常,异常的分类?" E% s$ x' \* m- J3 V
程序中导致程序中断的一些情况叫做异常,一般程序员可以处理。4 W7 ^4 H: e9 N) T5 r' _
异常分为运行时异常和非运行时异常(一般异常)
, x8 R) }( V+ k: G/ w) B9 k" U运行时异常是指因设计或实现方式不当导致的问题。也可以说,是程序员的原因导致的,本来可以避免发生的情况。例如:BufferOverflowException, ClassCastException,IndexOutOfBoundsException,ArithmeticException。出现这些异常的代码不需要try块包围。
* x/ s$ {. t6 t7 Z非运行时异常是指除运行时异常以外所有的异常,出现这些异常的代码必须用try块包围。例如:FileNotFoundException,EOFException, ]/ Y* s: x) x/ G$ F" [
; X: Z; z2 v! ]$ C' |5 i+ i
- 简述处理异常的两种方式?$ G* }" E7 M( d% G" R6 n& R$ q T
抛出(throws)和catch语句处理8 J; L1 U0 ]5 P" D9 H
9 m2 `+ F+ h! U' G# @/ H; h4 b- K7 r- 简述try块的功能和规则+ O) p! s) r) k
try块内部一般写一些编程人员认为可能会出现异常的代码,使程序运行时不会因为出现异常而中断。
2 H5 T z4 O$ W+ p' d- 简述catch块的功能和规则, {) k+ I6 r) i/ w9 @+ g& l
功能:可以截获所声明的异常,并在语句块内对其进行处理 规则:catch(Exeption e){ e.printStackTrace( ); } + G: ]) ?8 ]4 Q& F7 J, p# P
- 简述finally块的功能和规则4 U: Q3 z* I4 h6 S [2 f
finally块一般写一些不论是否发生异常都必须执行一次的代码 例如关闭与数据库的连接等 , A& F; L% P: N; X* z# e; M
- 简述throw和throws的功能和使用方法
, p8 V n0 c& v) H6 \
throw 指编程人员主动抛出一个异常 throw new NullPointerExeption( ); throws指程序遇到异常情况自动的被动抛出一个异常 public void test( ) throws Exeption{}
$ Z9 P/ k% y& |' l8 `/ A- 异常的分类?
. G: i$ t$ P$ V6 t" I* K( }$ ]
错误(Error): JVM 系统内部错误、资源耗尽等严重情况,程序员不可控制 例外(Exception):其它因编程错误或偶然的外在因素导致的一般性问题,程序可以控制 # E5 c7 b7 F9 b9 f. m, c
java程序中预先定义好的异常叫做预定义异常 ' J: L3 y! G+ t5 X) [1 n/ g
- 简述自定义异常的规则
$ s* b6 E% ^; V9 a* \5 {1 ]
写一个类继承Exception 用户自定义异常通常属Exception范畴,依据惯例,应以Exception结尾,应该由人工创建并抛出。
$ I3 p% b$ s. n: ]" y- 什么是断言?4 ^* W4 `6 _8 [6 P/ G. T8 m
用来证明和测试程序的假设。 $ f( F% R2 Z" v3 j: F: w
- 如何使用断言?举例说明
# e2 m8 m2 H* D+ Q9 p
一种是assert<<布尔表达式>>;另一种是assert<<布尔表达式>>:<<细节描述>>。 assert a= =10 : “这里a等于10″;
) `3 \! F9 }; U& v g+ u! c |