java面向对象程序设计基础知识总结_第1页
java面向对象程序设计基础知识总结_第2页
java面向对象程序设计基础知识总结_第3页
java面向对象程序设计基础知识总结_第4页
java面向对象程序设计基础知识总结_第5页
已阅读5页,还剩13页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、1、含有 main() 方法的类称为主类,一个.java 文件中可以有多个类,但只能有一个主类。2 、 转义字符:对于和, 需在前面加上,即用 char a =' ,b='' 表示。 n 表示回车换行; t 表示水平制表; b 表示退格;v 表示水平制表。 r 表示回车; a 表示警铃3 、 标识符: Java 程序中自定义的类名、方法名、参数都是标识符,Java 语言中规定标识符由字母(区分大小写)、数字、下划线、$自由组合而成,但不能以数字开头,标识符长度不限。4 、 基本数据类型:分 4大类 整数( byte :1字节 /int :4字节/short :2字节 /

2、long :8字节)、 浮点数(float :4字节 /double :8字节)、 字符型(char:2 字节)、 布尔型(boolean:1 字节)。5 、 整形变量注意: 16 进制数以 0x 开头, 8进制数以 0开头。6 、 浮点型变量注意:如果数字未加任何字母,则默认为double类型,赋值时须注意数据类型匹配问题。7、 数组的定义: char array1 。和 char array2 。都可以。8、 双目运算符: + - * / 对于整形和浮点数有效( float x = 1f/3f 。的运行结果是x=0.33333334) ,但 %只对整形运算。9 、 逻辑运算符:逻辑运算是对

3、布尔型变量进行运算,结果也是布尔型。 表示异或运算( ab 表示 a 和 b 真假不同时,值为真)。 && 和|是短路的(对于 a&&b, 如果 a 为假,则不再计算 b 的值), & 和|是非短路的, a 和 b 的值都要计算。10 、 位运算符: & 位与、 |位或、 位反、 位异或、 << 左移、 >> 右1/16移、 >>> 无符号右移 (忽略了符号位扩展,0补最高位 )。11 、 位运算注意: JAVA 进行移位运算中因为int 是占 32 位,进行移位的数是 32的模 ,long 占8字节也就

4、是 64 位,所以移位的数是 64 的模,byte 、 short 进行右移位运算,会自动转换成int 类型。12 、 左移运算: value << num:左移 num位,丢弃最高位, 0补最低位,如果移动的位数超过了该类型的最大位数,那么编译器会对移动的位数取模 (根据被移位数的类型而定模的大小 )。运算规则 : a.当左移的运算数是 int 类型时,每移动 1位它的第 31 位就要被移出并且丢弃; b. 当左移的运算数是 long 类型时,每移动 1位它的第 63 位就要被移出并且丢弃。 c.当左移的运算数是 byte 和 short 类型时,将自动把这些类型扩大为 int

5、型。 d. 在数字没有溢出的前提下,对于正数和负数,左移一位都相当于乘以2的1次方,左移 n 位就相当于乘以 2的 n次方13 、 右移运算: value >> num:符号位不变,左边补上符号位;运算规则:a.按二进制形式把所有的数字向右移动对应的位数,低位移出(舍弃 ),高位的空位补符号位,即正数补零,负数补1。b. 当右移的运算数是 byte 和 short 类型时,将自动把这些类型扩大为int 型。14 、 三目运算符(条件表达式): x?y:z 。表示 x 为真时,表达式的值是 y 的值,否则取 z 的值。 int x=1,y=2,z=3 。 int i = x<0

6、?y:z 。则i 的取值就是 3.15 、 java 中提供了四种转移语句:break 、continue、 return 、throw2/16break: 在 Java 中, break 语句有 3种作用。第一,你已经看到,在switch 语句中,它被用来终止一个语句序列。第二,它能被用来退出一个循环。第三,它能作为一种“先进”的goto语句来使用( breaklabel 。 标签 label 是标识代码块的标签。当这种形式的break 执行时,控制被传递出指定的代码块。被加标签的代码块必须包围break语句,但是它不需要是直接的包围break 的块。这意味着你可以使用一个加标签的break

7、 语句退出一系列的嵌套块。但是你不能使用break 语句将控制传递到不包含 break 语句的代码块)。16、 continue: 类似 break ,不带标签的 continue是终止当前循环结构,转而直接进入下一轮循环。而continue label。则是把程序直接转到 label 所指向的那一个循环结构的下一轮循环,而不管被它嵌套的及 continue 语句所在的循环结构运行到了哪一轮。17、 方法的调用及参数的传递:一个是传值(要求实际参数必须是简单类型的变量),一个是传递 地址 (数组 )。18、 类与对象:类是对对象的抽象,而对象是对类的具体化或实例化。19、 类头说明:类名第一个

8、字母大写并体现该类的功能或特征。类的修饰符分两种:一是访问控制符,如public ;一是类型说明符 ,类型说明符只有两个:abstract和 final 。20 、 类的访问控制符:一个是public ,可以被所有的类访问和引用,其他包用import语句引入后可调用;一个是默认的,也就是没有控制符,也称为友好的friendly, 包中的类能用而不能被其他包3/16中的类访问或使用( import 引入也不行)。 注意:import 语句引入的类必须是 public 修饰的类, Java 规定一个 .java 文件可以有多个类,但必须有一个而且最多有一个 public 类,因而文件中的其他类只能

9、是友好访问控制符。21 、 属性和方法的访问控制符:public 、private (私有访问控制符,只能被该类自身所访问或调用)、protect (保护访问控制符,它可被同一个包中的其他类、不同包中的该类的子类及自身调用)、private protect(只能被该类自身及该类的子类访问和引用)、默认访问控制符(具有包内访问性,只能被同一个包中的其他类访问或引用,不在同一个包中的类不能访问它,即使用import语句引入也不行)22 、 static :只能修饰属性和方法,修饰的属性和方法不用实例化,可以用类直接调用。23 、 多个修饰符放在一起使用:abstract不能与 final 共同修改

10、一个类; abstract不能与 private,static,final和 native 共同修饰一个方法; abstract类中不能有私有属性和方法。24 、 另一种创建对象的方法:假设一个类名为Text ,它有一个方法名为 print() ,则可以直接用下面的语句创建对象并其方法:newText().print()。不过这个对象是无名,所以不能被再次调用。25 、 构造函数:构造函数名字必须与类名完全相同,没有返回值也不用 void 指明,还可以通过重载实现不同的初始化方法。26 、 Java 允许类的嵌套 :因此类的默认访问控制符有两个:一个是4/16友好类 default ,一个是类

11、中类,一个友好类编译后能后生一个独立的.class 文件,如 Input.class ,而类中类却产生Judge$Imput.class,所以只能被包含它的类使用。27 、 命令行参数: main() 方法是通过 String args这个字符串数组来接收命令行参数的。28 、 继承:一个子类只能继承一个父类,这样继承关系就形成了一棵树。继承能够使子类拥有父类非私有的属性和方法。子类通过super来调用父类的属性和方法。29 、 多态:指一棵继承树的类中可以有多个同名但不同方法体以及不同形参的方法。分两种情况覆盖和重载。 覆盖是在子类中直接定义和父类同样的属性和方法,而重载是指在同一个类定义中

12、有多个同名的方法,但有不同的形参。覆盖:子类与父类的关系,是在子类中直接定义和父类同样的属性和方法,但重新编写了方法体,即子类与父类的形参与返回值都相同,但内部处理不同。 通过调用它的对象来决定调用哪个方法。重载:同一个类内部多个方法间的关系,是指在同一个类定义中有多个同名的方法,但不同的形参,而且每个方法有不同的方法体,调用时根据形参的个数和类型来决定调用的是哪个方法。 通过形参表来决定调用哪个方法。30 、 在 Java 技术中,另一个必须要求有重载存在的原因是构造函数。31 、 继承了父类的属性表示子类被创建时另外开辟了新的空间来存5/16储从父类继承而来的属性,其初值应该是父类中属性的

13、初值,但之后双方的相同属性彼此相互独立。32 、 final 修饰的方法不能被子类覆盖,但可以被重载。abstract修饰的方法必须被子类覆盖。33 、 this 的使用:this 关键字(只能在方法内部使用)可以为调用了自己的方法的那个对象生成相应的地址,可以像对待其他任何对象地址一样对待。public class Leaf private int i=0。Leaf increment()i+ 。return this。 / 将当前对象的地址作为返回值返回void print()。public static void main(String args)Leaf x = new Leaf()。

14、x.increment().increment().increment().print()。 / 多次调用方法/ increment(),返回的都是对象x 的地址, i 值表示调用次数6/1634 、 super的作用:它并不是父类对象的地址,它专门用来指代父类,也就是说super 的含义是被修饰的属性和方法将使用父类的定义,而非子类本身的定义,因此子类的对象想使用它父类中的同名属性和方法时 ,就可以使用super 。35 、构造函数:如果定义了多个构造函数,创建对象时必须使用其中之一,因为系统不再定义默认的空构造函数了。构造函数的简化 (调用 ) :用构造函数间的 调用可以实现定义的简化,就

15、是先调用定义好的构造函数完成部分属性的初始化,再加上其他属性的赋值。public class Leaf private String lname。private int lnum。Leaf(int num)lnum = num。Leaf(int $num,String $name)this($num)。/ 调用上一个构造函数,等同于lnum = $num。lname = $name。public static void main(String args)Leaf x = new Leaf(20,"good")。7/16。Leaf y = new Leaf(22)。调用其他构

16、造函数时,必须加上this 代替函数名,但这时的this 不代表地址,只用来表示构造函数的名称,也就是类名。注意要在实际参数名前加上 $作为开参名,这样既区别于实际参数名,又能反映形参的含义。构造函数的继承: A、子类只能继承父类的默认构造函数,即无形参构造函数,并且在创建对象时先调用这个构造函数对对象进行初始化,再调用子类自己定义的构造函数。B、如果父类没有默认构造函数,子类将不能从父类继承到任何构造函数,并且子类也不能定义自己的无参数构造函数。C、如果子类想调用父类的非默认构造函数,必须使用super来实现。例如调用父类的构造函数并加入自己的定义:NormalStudent($stuFla

17、g,$sName,$sSex,$reduceFlag)super($stuFlag,$sName,$sSex)。/ 此处调用的是父类的构造函数对形参 $stuFlag,$sName,$sSex初始化。reduceFlag = $reduceFlag。8/16D、子类的构造函数的形参表只能使用父类构造函数中用过的形参表,或者是对它的扩展。例如父类的构造函数只有一个: Super(int i,String s),那么它的子类只能定义这样的构造函数:subbie(inti,String s,char c) 等。36 、最终类成员 A 用 final修饰的方法是不能被该类的子类所重载的方法。B、用 f

18、inal 修饰的简单变量相当于常量,不管这个变量是属性还是自变量,这时相当于编程者用一个名称来代替一个常量。如果类的属性是常量,那么它的各个对象的这个值一定相同,所以final 通常和static 放在一起修饰属性,以节省内存空间;另外final 的修饰的简单变量通常是所有字母大写,以表示它是常量。37 、静态变量、动态变量区别A、对于静态变量在内存中只有一个拷贝(节省内存),JVM 只为静态分配一次内存,在加载类的过程中完成静态变量的内存分配,可用类名直接访问(方便),当然也可以通过对象来访问(但是这是不推荐的)。 B、对于实例变量,每创建一个实例,就会为实例变量分配一次内存,实例变量可以在

19、内存中有多个拷贝,互不影响(灵活)。38 、对象在继承关系中的改变:A、子类实例可以被当作父类的一个对象使用,而父类实例不能被当作子类的一个对象使用。子类对象可赋予父类对象,父类对象赋予子类对象则出错B、如果一个父类对象通过赋值指向的地址是子类对象所在的地址,按9/16照前一条规则,这个对象仍然是父类的对象。但它可以通过强制类型转换变成子类对象,这种转换只能用在对象间赋值时,不能单独使用强制转换。以上规则可以这样理解:子类对象所占的内存在一般情况下比父类对象所占的内存空间大,父类对象中的成员都可以在子类对象的地址中找到对应部分,所以可以把子类对象当作父类的一个对象用。而相反时,子类对象的成员并

20、不一定能在父类对象地址中找到对应部分,这样就可能造成成员丢失。而强制类型转换则是因为父类对象本身就与子类对象的地址相对应(从子类转换而来 ),当然可以把这个对象转换成子类的对象,而不造成成员的丢失。public class ObjectConvert public static void main(String args)SuperClass superA = new SuperClass(),superB。Subbie subA = new Subbie(),subB。/ 用子类对象作为实际参数传递给应是父类对象的形参(new ObjectConvert().useSubAsSuper(su

21、bA)。superB = subA。/ 把子类对象赋予父类对象。/ 如果输出中仍用方法getY() 将出错。/ subB = superA 。 / 把父类对象赋予子类对象将出错/ 把指向子类对象地址的父类对象superB 强制转换成子类对象,并赋予 subBsubB = (Subbie)superB。/ 子类对象还相当于是原来的子类对象subApublic void useSubAsSuper(SuperClass x)。10/16class SuperClassprivate int x = 100。public int getX()return x。class Subbie extends

22、 SuperClassprivate int y = 200。public int getY()return y。39 、抽象类:抽象类的属性和方法是它的子类的公共属性和方法的集合。 A、用 abstract 修饰的方法是抽象方法,所有的抽象方法都必须在抽象类中, 抽象方法只有方法头而无方法体。定义格式如下:abstract返回值类型方法名 ( 形参 ) 。B、抽象类可以包含抽象方法和一般方法,继承它的非抽象子类必须实现其所有的抽象方法(注意是覆盖而不是重载),对于抽象类中的一般方法的继承和普通的继承一样,只要该方法是非private的就可以继承。C、抽象类的实例:抽象类不能有实例,但有一种情

23、况例外,就是定义一个抽象类的对象名(引用)指向它的非抽象子类的对象。这也就是38(B) 中介绍的情况,这时的抽象类实例只含有父类所有的方法,而没有子类新增加的方法。可以这样理解:一个对象名或方法名相当于一个指针,父类的对象指向了子类的实例对象,因此父类对象的方法找到了指针的目标,就是子类对象中的同名方法,而对于子类对象中私11/16有的方法 C(),父类对象中没有指针指向C() ,也即父类对象根本不知道有方法 C() 的存在,所以父类对象不能调用子类对象方法C()。D、抽象类可以有抽象方法也可以没有抽象方法。但是如果一个类有抽象方法,那这个类只能定义为抽象类。E、如果是抽象类实现一个接口,那么

24、抽象类中可以不具体实现接口的方法 (保持其抽象性 ),而由其子类去实现。40 、接口:接口在语法上和类很相似,它的属性都是常量(用final修饰),方法都是抽象方法(abstract),没有方法体,接口间也可以形成继承关系。定义:public interface接口名 extends父接口名 1,父接口名 2, public static final属性数据类型属性名 1 = 值; / 必须给出属性值public abstract native返回值类型 方法名(形参表) throw例外名列表 。说明: 1、puiblic 表示它可以被不同包中的类或接口使用,没有用 public 表示它是友好

25、的( default ),具有包内访问性。 Interface 的修饰符只能为 public 或默认( default )。2 、子接口将继承所有父接口的所有属性和方法3 、接口的属性必须是public static final(静态常量)修饰的,12/16这是被系统默认的,所以可以不写,但一般写出final (所以接口的属性必须给出属性值)4、 接口的方法系统默认为public abstract的,一般不写修饰符5、一个接口可以没有任何接口体,但大括号不能省略,这种接口一般是接口继承结构中一个最顶层的父接口接口与抽象类的区别:接口中不能有非抽象的方法,但抽象类中可以有一个类能实现多个接口,但

26、只能有一个父类接口与继承无关,所以无关的类可以实现同一个接口。接口的实现: 必须在类的定义时用关键字 implements 来声明一个类声明实现某个接口后必须实现该接口的全部方法(包括该接口的所有父类的方法),被实现的方法和接口定义的方法有完全一样的方法名、返回值和形参表。被实现的方法的访问控制符必须显式地使用 public 修饰,因为接口的方法都是 public 的。41 、适配器:当我们只需要使用某个接口中的少部分方法时,可以继承与之相对应的抽象类(抽象类不用实现所有的方法?)。java 类库为所有的接口都提供了与之相对应的抽象类,我们称之为适配器。? 42 、例外:java 允许我们声明

27、抛出一个并没有发生的例外,可将其作为一个“占位符”来理解。A、java 提供了一个名为Throwable的类,所有的例外都必须是它或它子类的实例。 Throwable有两个子类: Error 和 Exception ,其中13/16Error 代表编译期和系统错误,我们一般不用特意捕获它们。Exception是可以从任何标准Java 库的类方法中招聘的基本例外类,它们亦可以从我们自己的方法或者在运行期偶发事件中抛出。java 定义的例外类都是 Exception 的子类。 -B、 catch的括号内定义的对象名必须是try 块中可能抛出的例外类的同一个类或父类、甚至祖先类。因此说用catch(

28、Exception e) 能捕获所有例外就不奇怪了。C、异常的继承结构:基类为 Throwable,Error和 Exception继承Throwable,RuntimeException和 IOException等继承Exception,具体的 RuntimeException继承 RuntimeException。D、 Error和 RuntimeException及其子类成为 未检查异常 ?( unchecked ),其它异常成为已检查异常( checked )E、例外在继承关系中的特殊性:子类方法只能抛出被父类方法所能抛出的例外所属的例外类或它的衍生类,如果父类方法未定义成抛出例外,那

29、么子类覆盖方法也不能抛出例外,如果父类方法声明抛出例外,子类方法可以不声明抛出例外。但是,父类的构造函数如果声明抛出例外,则子类的构造函数也必须声明抛出,子类也可以抛出根本不存在的例外。43 、 RuntimeException介绍1) 、NullPointerException (值为空):见的最多了,其实很简单,一般都是在 null 对象上调用方法了。String s=null。14/16boolean eq=s.equals("")。 / NullPointerException这里你看的非常明白了,为什么一到程序中就晕呢?public int getNumber(String str)if(str.equals("A") return 1。else if(str.equals("B") return 2。这个方法就有可能抛出NullPointerException,我建议你主动抛出异常,因为代码一多,你可能又晕了。public int getNumber(String str)if(str=null)throw new NullPointerException("参数不能为空 &

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论