◆传值与传引严格来说, Java 中所有方法参数都是传值。因为即使是传递的参数是对象的引数时, 引数本身也是传值的。所有基本类型都是传值的。传值: 被传入的参数被视为内部的局域变量,其变化不影响外部变量的原始值。传引: 对于引数本身来讲也是传值的, 但是在方法内部若对引数所指向的对象属性有改变, 则会直接实时地影响所指向的对象属性。理解传引这一概念的最佳方式就是画出指向图。 eg. A?(Object)O 对于 A 本身而言它是传值的, 也就是说当 A 作为参数传递的时候, 假若在方法内部把其它的引数赋给了 A, 但是当方法返回时,A 仍旧是指向原来的对象, 而不会改变。其次, 对于传引来说, 假若在方法内部对 A 所指向的对象属性有改变,那么对象属性的改变会是直接实时的。再次强调, Java 中所有的参数传递都是传值的。传值这种题型的考试很多, 基本类型传值问题考的较多的是对某一变量, 故意用某一方法试图改变它,然后方法返回时再打印它。按传值的说法,实际上该变量并没有改变。◆构造函数 a .构造器没有任何返回类型,哪怕是 void 也不行。假如指定了返回值,那么 Java 会视为一个普通的方法。 b. 如果没有显示地调用父类的构造器, Java 总是自动地调用父类的默认构造器。( 也就是第一行会默认为 super( )) c. 只要类中显式地定义一个或多个构造器, 那么 Java 不会再为你定义一个默认的构造器 d. 构造函数可以被重载, 并且在其体内可以用 this() 和 super() 来调用其它的构造器。但是 this() 和 super() 只能放在构造函数体的第一行进行调用。 e. 构造器的修饰符只可以是接入控制符 public 、 private 、 protected 、(default) 。其它修饰符一律不可。 f .构造方法不可被继承。◆重载与覆盖重载的英文为 Overload ,而覆盖的英文为 Override 。重载是出现在同一类中多个同名函数,而覆盖是出现在类继承体系中同名函数。(注意:覆盖有时被称为重写) 重载是依据同名方法参数的个数、参数的类型和参数的顺序来确定的。方法的修饰符、返回值、抛出的异常均不能作为区分重载方法的依据。(继承体系中也有重载现象) 覆盖是在继承体系中子类覆盖超类中定义的方法。子类中覆盖方法的返回类型和参数类型必须精确匹配。接入控制符只能更加公有化; 抛出的异常是超类抛出的子集或不抛。( static 方法不能覆盖, private 方法也不能覆盖。 Java 视它们为被隐藏) ?参数类型一致, 返回类型不同, 编译错误, 提示“试图用不兼容的返回类型覆盖”。?只要参数类型不一致,返回类型同与不同,编译都能通过,此不为覆盖而是重载。◆多态多态是出现于类的继承层次中,通过向上转型和方法重写的机制来实现的。面向对象程序设计的目标是: 希望所撰写的程序代码都只对基类进行操作。这么一来, 当加入新的继承类时, 大部分程序代码都不会受影响而改写( 也即是说代码具有扩充性)。所以当调用新加入的继承类时,都会首先向上转型为基类。这就是多态的向上转型。当你希望通过调用基类的方法而能让继承类产生正确的行为时, 这显然需要在继承类进行重写该方法。而究竟是该调用哪个继承类,这是由 Java 的动态绑定决定的。多态最重要的一点在于 run-time binding 。多态是面向对象程序设计的目标。关于多态中覆盖注意如下: 属性既可以继承, 也是可以“覆盖”的。但是对属性而言没有动态绑定这一特性, 所以覆盖的属性被认为是子类的特别属性。从某种意义上来讲,属性决定了类(性质) 。另一方面, 申明的类型就决定了对象的属性。这是因为, 任何对象或变量等号右面是用来赋值给符合等号左面所申明类型的,所以左面的类型是先决条件,赋值必须要符合申明类型。对于向上转型而言, 因为等号右面的对象 isa 申明类型, 所以是成立的。一定要记住, 属性永远都是跟着申明类型走。但是,对方法而言是在运行时动态绑定的, 它取决于对象自身的实际类型( 实际上对方法而言, 也是先检查向上转型后的基类该方法, 若无该方法的定义,则编译错,然后再动态绑定到继承类的覆盖方法)。另外, static 方法不能覆盖, private 方法也不能覆盖。还需特别注意,方法覆盖时,若覆盖得不对(例如参数一致,仅依靠返回类型不同) ,则编译会出错, 而不是被 Java 认为方法重载( 除非参数类型也不一样, 这样 java 会认为不是 override ,实际上它是 overload )。◆类初始化类的初始化大致上有这么几个方面。 a .静态变量的初始化 b .一般实例变量的初始化 c .构造函数的初始化初始化的难点在于继承体系中。当有继承体系时, 初
Java重要知识点 来自淘豆网m.daumloan.com转载请标明出处.