這三種關係能夠同時存在,可是有先後順序:ide
extends -> mixins -> implements
extens在前,mixins在中間,implements最後函數
Flutter中的繼承和Java中的繼承是同樣的:this
Flutter中的繼承是單繼承spa
class Person {
//公有變量 String name; num age;
//私有變量 String _gender; //類名構造函數 Person(this.name,this.age);
//公有的方法 void printInfo() { print("${this.name}---${this.age}"); }
work(){ print("${this.name}在工做..."); } } class Web extends Person{
Web(String name, num age) : super(name, age);
run(){ print('run'); super.work(); //自類調用父類的方法 }
//覆寫父類的方法 @override //能夠寫也能夠不寫 建議在覆寫父類方法的時候加上 @override void printInfo(){ print("姓名:${this.name}---年齡:${this.age}"); } } main(){ Web w=new Web('李四',20); // w.printInfo(); w.run(); }
class Person{ String name; num age; Person(this.name,this.age); printInfo(){ print('${this.name}----${this.age}'); } void run(){ print("Person Run"); } } class A { String info="this is A"; void printA(){ print("A"); } void run(){ print("A Run"); } } class B { void printB(){ print("B"); } void run(){ print("B Run"); } } class C extends Person with B,A{ C(String name, num age) : super(name, age); } void main(){ var c=new C('張三',20); c.printInfo(); // c.printB(); // print(c.info); c.run(); }
Flutter是沒有interface的,可是Flutter中的每一個類都是一個隱式的接口,這個接口包含類裏的全部成員變量,以及定義的方法。若是有一個類 A,你想讓類B擁有A的API,但又不想擁有A裏的實現,那麼你就應該把A當作接口,類B implements 類A.
因此在Flutter中:class 就是 interfacecode
/* Dart中一個類實現多個接口: */ abstract class A{ String name; printA(); } abstract class B{ printB(); } class C implements A,B{ @override String name; @override printA() { print('printA'); } @override printB() { // TODO: implement printB return null; } } void main(){ C c=new C(); c.printA(); }