惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

AI
AI
TaoSecurity Blog
TaoSecurity Blog
H
Heimdal Security Blog
Help Net Security
Help Net Security
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Microsoft Azure Blog
Microsoft Azure Blog
www.infosecurity-magazine.com
www.infosecurity-magazine.com
Google DeepMind News
Google DeepMind News
爱范儿
爱范儿
The Cloudflare Blog
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
人人都是产品经理
人人都是产品经理
大猫的无限游戏
大猫的无限游戏
N
News | PayPal Newsroom
V2EX - 技术
V2EX - 技术
博客园 - 【当耐特】
D
Darknet – Hacking Tools, Hacker News & Cyber Security
S
Secure Thoughts
C
CERT Recently Published Vulnerability Notes
罗磊的独立博客
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
P
Privacy & Cybersecurity Law Blog
有赞技术团队
有赞技术团队
S
Schneier on Security
S
SegmentFault 最新的问题
Google Online Security Blog
Google Online Security Blog
H
Hacker News: Front Page
The Last Watchdog
The Last Watchdog
Schneier on Security
Schneier on Security
PCI Perspectives
PCI Perspectives
IT之家
IT之家
Project Zero
Project Zero
博客园 - 司徒正美
P
Privacy International News Feed
Recent Commits to openclaw:main
Recent Commits to openclaw:main
Jina AI
Jina AI
Security Latest
Security Latest
Hacker News - Newest:
Hacker News - Newest: "LLM"
腾讯CDC
C
CXSECURITY Database RSS Feed - CXSecurity.com
阮一峰的网络日志
阮一峰的网络日志
C
Check Point Blog
aimingoo的专栏
aimingoo的专栏
V
Vulnerabilities – Threatpost
W
WeLiveSecurity
NISL@THU
NISL@THU
Webroot Blog
Webroot Blog
N
Netflix TechBlog - Medium
L
Lohrmann on Cybersecurity

博客园 - 泽来

java多线程---线程之间的通信 设计原则 适配器模式 java复习进程 java小点滴 转>java5.0新特性 面试题收集 我买的书 javascipt正则表达式 - 泽来 - 博客园 javascript小代码 - 泽来 - 博客园 DataGrid数据在Execel中打开 - 泽来 - 博客园 javascript高级教程 智力题收集 asp.net的TextBox回车触发事件 - 泽来 - 博客园 Builder生成器模式 单件模式(singleton) 是男人就坚持100下(强力益智,请留下战绩) XMLHTTP简介 - 泽来 - 博客园 多级无刷新联动(GB2312编码转换为UTF-8未取得满意效果) - 泽来 - 博客园
java编程思想中关于多态性的描述
泽来 · 2005-12-30 · via 博客园 - 泽来

多态性是继数据抽象和继承之后,面向对象语言的第三个特征。
它提供了另一个层面的接品与实现分离,也就是说把  做什么  和  怎么做分离开来。
 多态性是一项很重要的技术,它能够将会变的和不会变的东西分隔开来

一些代码

import java.util.*;

class Note
{
    
private String noteName;
    
private Note(String noteName)
    
{
        
this.noteName = noteName;
    }

    
public String toString()
    
{
        
return noteName;
    }

    
public static final Note
        A 
= new Note("A"),
        B 
= new Note("B"),
        C 
= new Note("C");    
}

class Instrument
{
    
void play(Note note)
    
{
        System.
out.println("Instrument.play()"+note);
    }

    String what()
    
{
        
return "Instrument";
    }

    
void adjust(){}
}

class Wind extends Instrument
{
    
void play(Note n)
    
{
        System.
out.println("Wind.play()" + n);
    }

    String what()
    
{
        
return "Wind";
    }

    
void adjust(){}
}


class Percussion extends Instrument
{
    
void play(Note n)
    
{
        System.
out.println("Percussion.play()"+n);        
    }

    String what()
    
{
        
return "Percussion";
    }

    
void adjust(){}
}


class Stringed extends Instrument
{
    
void play(Note n)
    
{
        System.
out.println("Stringed.play()"+n);
    }

    String what()
    
{
        
return "Stringed";
    }

    
void adjust(){}
}


class Brass extends Wind
{
    
void play(Note n)
    
{
        System.
out.println("Brass.play()"+n);
    }

    
void adjust()
    
{
        System.
out.println("Brass.adjust()");
    }

}

class Woodwind extends Wind
{
    
void play(Note n)
    
{
        System.
out.println("Woodwind.play()"+n);
    }

    String what()
    
{
        
return "Woodwind";
    }

}


public class HelloWord
{
    
public static void tune(Instrument i)
    
{
        i.play(Note.C);
    }

    
public static void tuneAll(Instrument[] e)
    
{
        
for(int i = 0; i < e.length; i++)
        
{
            tune(e[i]);
        }

    }

    
public static void main(String[] args)
    
{
        Instrument[] orchestra 
= {
                
new Wind(),
                
new Percussion(),
                
new Stringed(),
                
new Brass(),
                
new Woodwind()
        }
;        
        tuneAll(orchestra);
        
    }

}


1.当你想要通过一个公共的接口来控制一组类的时候,就可以使用抽象类.
2.如果构造函数调用了一个动态绑定的方法,且那个方法又属于那个正在创建中的对象,那么它会使用那个覆写后的版本。===》一个好的构造函数应该用尽可能少的工作量去把属性初始化并尽量少的调用方法.