注:看此篇时强烈建议有一定的面向对象思想基础,有一定的基础后先翻到下面看第九条:9.面向对象: 从未封装→封装→继承→多态→抽象类→接口的代码演变,按这个逻辑去看,哪有不理解的再回头看知识点,这是掌握理解最好最快的方法,切记切记
描述一个物质都可以通过两方面说明:数据模型(属性)、行为模型(行为)。在Java编程中,我们使用成员变量表示数据模型,用成员方法表示行为模型。使用类表示某些具有相同属性和行为的事物。
语法:
访问修饰符 类名(){ }
作用:
构造函数,一般是用于为成员属性赋初始化值;
注意:
如下例所示,static修饰符用来创建类方法和类变量:
public class InstanceCounter {
private static int numInstances = 0;
protected static int getCount() {
return numInstances;
}
private static void addInstance() {
numInstances++;
}
InstanceCounter() {
InstanceCounter.addInstance();
}
public static void main(String[] arguments) {
System.out.println("Starting with " +
InstanceCounter.getCount() + " instances");
for (int i = 0; i < 500; ++i){
new InstanceCounter();
}
System.out.println("Created " +
InstanceCounter.getCount() + " instances");
}
}
运行结果:
Starting with 0 instances
Created 500 instances
Java中可以使用访问控制符来保护对类、变量、方法和构造方法的访问。Java 支持 4 种不同的访问权限。
我们可以通过以下表来说明访问权限:
为了实现一些其他的功能,Java 也提供了许多非访问修饰符。
final修饰变量:
//实例
public class Test{
final int value = 10;
// 下面是声明常量的实例
public static final int BOXWIDTH = 6;
static final String TITLE = "Manager";
public void changeValue(){
value = 12; //将输出一个错误
}
}
final修饰方法:
如下所示,使用 final 修饰符声明方法:
public class Test{
public final void changeName(){
// 方法体
}
}
final修饰类:
//实例
public final class Test {
// 类体
}
注意:
abstract修饰符,用来创建抽象类和抽象方法。
抽象类:
规则:
实例:
abstract class Caravan{
private double price;
private String model;
private String year;
public abstract void goFast(); //抽象方法
public abstract void changeColor();
}
抽象方法
实例:
public abstract class SuperClass{
abstract void m(); //抽象方法
}
class SubClass extends SuperClass{
//实现抽象方法
void m(){
.........
}
}
synchronized 和 volatile 修饰符,主要用于线程的编程。
synchronized 修饰符
synchronized 关键字声明的方法同一时间只能被一个线程访问。synchronized 修饰符可以应用于四个访问修饰符。
实例
public synchronized void showDetails(){
.......
}
transient 修饰符
实例
public transient int limit = 55; // 不会持久化
public int b; // 持久化
**volatile **修饰符
实例
public class MyRunnable implements Runnable
{
private volatile boolean active;
public void run()
{
active = true;
while (active) // 第一行
{
// 代码
}
}
public void stop()
{
active = false; // 第二行
}
}
通常情况下,在一个线程调用 run() 方法(在 Runnable 开启的线程),在另一个线程调用 stop() 方法。 如果 第一行 中缓冲区的 active 值被使用,那么在 第二行 的 active 值为 false 时循环不会停止。但是以上代码中我们使用了 volatile 修饰 active,所以该循环会停止。
this指当前对象,用法:
私有的属性,公开的方法。
封装的步骤:
Java中的继承是单继承,可以实现多层继承,继承的关键字extends
语法:
public class Son extends Father{
}
规则:
重写定义:
实现的必要条件:
instanceof关键字:
语法:
if (对象名 instanceof 类名) {
类型转换代码;
}
实例:
Animal cat = new Cat();
if (cat instanceof Cat) {//返回结果为boolean类型
Cat c = (Cat) cat;
c.eat();
}else{
System.out.println("类型不匹配");
}
语法:
public interface ITest {
}
规则:
未封装:
public class Person {
int age;//年龄
String name;//姓名
public void print()
{
System.out.println("age:"+this.age+" "+"name:"+this.name);
}
}
class Text{
public static void main(String[] args) {
Person person = new Person();//实例化对象
person.age = -100;//赋值
person.name = "张三";
person.print();//执行类中的方法
}
}
运行结果:<br>age:-100 name:张三
封装:
public class Person {
private int age;//年龄
private String name;//姓名
public void setName(String name) {
this.name = name;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Person{" +
"age=" + this.age +
", name='" + this.name + '\'' +
'}';
}
}
class Text{
public static void main(String[] args) {
Person person = new Person();
person.setAge(20);
person.setName("张三"); ;
String s = person.toString();
System.out.println(s);
}
}
运行结果:
Person{age=20, name='张三'}
继承
public class Office {
public void print(){
System.out.println("打印");
}
}
class Word extends Office {
@Override
public void print() {
System.out.println("Word打印");
}
}
class Test{
public static void main(String[] args) {
Word word = new Word();
word.print();
}
}
运行结果:
Word打印
一个Java源文件中可以声明多个class类,但只能有一个public修饰的类。
多态
public class Office {
public void print(){
System.out.println("打印");
}
}
class Word extends Office {
@Override
public void print() {
System.out.println("Word打印");
}
}
class Excle extends Office{
@Override
public void print() {
System.out.println("Excel打印");
}
}
class Ppt extends Office{
public void daYin() {//子类可以重写父类方法,也可以自己定义方法
System.out.println("PPT打印");
}
}
class Test{
public static void main(String[] args) {
Office o = new Word();//多种形态,即多态
o.print();
}
}
运行结果:
Word打印
class Test{
public static void main(String[] args) {
Office o = new Excle();
o.print();
}
}
运行结果:
Excel打印
class Test{
public static void main(String[] args) {
Office o = new Ppt();
o.print();
}
}
运行结果:
打印
为避免这种方法名称多样的情况,用一种约束叫抽象类
public abstract class Office {
public abstract void print();
}
class Word extends Office {
@Override
public void print() {
System.out.println("Word打印");
}
}
class Excle extends Office{
@Override
public void print() {
System.out.println("Excel打印");
}
}
class Ppt extends Office{
@Override
public void print() {
System.out.println("PPT打印");
}
}
class Test{
public static void main(String[] args) {
Office o = new Ppt();//父类引用指向子类对象,子类重写父类方法,父类引用调用子类重写后的方法,执行的结果是子类重写后的方法
o.print();
}
}
运行结果:
PPT打印
接口是完全抽象的抽象类,并且可以多实现
接口默认为:
public class abstract interface Office {
public abstract void print();
}
---------------------------------------------------------
public interface Office {
void print();
}
class Word implements Office {
@Override
public void print() {
System.out.println("Word打印");
}
}
class Excle implements Office{
@Override
public void print() {
System.out.println("Excel打印");
}
}
class Ppt implements Office{
@Override
public void print() {
System.out.println("PPT打印");
}
}
class Test{
public static void main(String[] args) {
Office o = new Ppt();
o.print();
}
}
运行结果为:
PPT打印
成员内部类
成员内部类声明在类中,方法体、代码块之外。和成员变量、成员方法在同一级别。
语法:
public class Out {
//成员内部类
public class Inner{
}
}
实例化成员内部类:
//先实例化外部类
Out o = new Out();
//使用外部类对象,再实例化内部
Out.Inner inner = o.new Inner();
实例:
public class Out {
//成员变量
public int a = 1;
//成员内部类
public class Inner{
public int a = 2;
//内部类的成员方法
public void print(){
//执行内部类中的实例变量a
System.out.println(a);
//执行外部类的实例变量a
System.out.println(Out.this.a);
}
}
}
静态内部类
声明的位置参考成员内部类。
语法:
public class Out {
//静态内部类
public static class Inner{
}
}
实例化静态内部的对象:
Out.Inner inner = new Out.Inner();
实例:
public class Out {
public static int a = 1;
public int b = 3;
//静态内部类
public static class Inner{
public static int a = 2;
public static void print(){
//执行静态内部的静态变量
System.out.println(a);
//执行外部类的静态变量
System.out.println(Out.a);
//执行外部类的实例变量
Out o = new Out();
System.out.println(o.b);
}
}
}
局部内部类
声明在方法体或代码块内,作用域范围在方法体或代码块内。
语法:
public class Out {
public void method(){
//局部内部类
class Inner{
//局部内部类的成员方法
public void print(){
System.out.println("局部内部类");
}
}
//实例化局部内部类
Inner inner = new Inner();
inner.print();
}
}
执行局部内部类的方法:
Test类:
public static void main(String[] args) {
Out o = new Out();
o.method();
}
匿名内部类
语法:
父类名/接口名 对象名 = new 父类名/接口名(){
//匿名内部类成员
};
实例:
父类
public class Father {
}
匿名内部类:
public class Out {
public void method(){
//匿名内部类对象
Father f = new Father(){
};
}
}
这一篇对新手是不友好的,不过对一些一知半解的或者想复习的朋友可能帮助更大。