這三種關係能夠同時存在,可是有先後順序:ide
extends -> mixins -> implements
extens在前,mixins在中間,implements最後;函數
dart中的繼承規則:post
栗子舉起來:this
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 =n ew 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 就是 interfacespa
/* 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(); }