磨刀- Dart 类

2020-03-30  本文已影响0人  态度哥

✨✨✨✨✨ 魏什么_多喝水 Flutter 之路

声明:

// 所有的类都集成于Object ,Object没有父类
class Person1 {

    //定义属性
    String name;
    int age;
    String _sex; //通过下划线定义私有属性

    //构造函数
    Person1(this.name,this.age);

    //定义实例方法
    void fun1() {

    }

    //重写父类方法
    @override
    String toString() {
        // TODO: implement toString
        return 'name: $name, age: $age';
    }

创建实例

var person = Person1('wei',18);
person.fun1();

构造函数

}

    void main() {

        var person = Person2('wei', 18);
        print('name: $person.name,age:$person.age');
        //调用可选参数需要 paramName: value的形式指定为哪个可选参数赋值:如city
        var person1 = Person2('dong', 18,city: '济南');
        print('city: $person.city');
    }
```
///工厂构造方法演示
class Logger {
     static Logger _cache;

     //  工厂构造方法:
     //  不仅仅是构造方法,还是单例模式
     factory Logger() {
         if (_cache == null) {
         _cache = Logger._internal();
         }
         return _cache;
     }

     Logger._internal();

     void log(String msg) {
         print(msg);
     }
}

setters 和 getters

class Person5 {

    String _school; //私有属性
    String name ;


    //可以为私有字段设置getter来让外界获取到私有字段
    String get school => _school;

    //可以为私有字段设置setter来控制外界对私有字段的修改
    set school(String value) {
        _school = value;
    }
}

var main() {
    var person = Person5();
    //用set方法赋值
    person.school = '衡水中学';
    //用getang方法获取到school的值
    print(person.school);
}

抽象类

///继承抽象类要实现它的抽象方法,否则也需要将自己定义成抽象类
class StudyFlutter extends Study {
  @override
  void study() {
    print('我爱学习,我爱Flutter');
  }
}

abstract class Study {
  void study();
}

继承

继承普通类

class  PersonO {

        String name;
        int age;

        PersonO(this.name,this.age);//普通构造函数
        PersonO.run(String name){ //命名构造函数
            this.name = 'my name: $name';
        }

        fun1() {
            print('fun1');
        }
}
class StudentO extends PersonO {

        String name;
        int nums;
        int color;
        //至少需要定义一个构造函数调用父类的任一构造函数
        StudentO(String name, int age) : super(name, age);

        //重写父类的方法
        @override
        fun1() {
            // TODO: implement fun1
            return super.fun1();
        }
  
        //子类自己的方法
        void fun2(){
            print(nums);
        }
    }

按住option会给出提示

minxins

class  Person001 {

  String getName() => 'wei1' ;//三个类都有
  String getAddress() => '历下区'; //该类独有
}

class Person002 {
  String getName() => 'wei2';//三个类都有该方法
  String getColor() => "2   red";//该类独有
  int getNum()=> 6;//该类和OtherClass都有
  String getCity()=>"济南";
}

class OtherPerson {
  String getName() => 'wei2';//三个类都有该方法
  int getNum() => 3; //该类和With2都有
  int getDesk() => 333;//该类独有

  String getPhone()=>"OtherPerson  123";//该类和子类
  String getCity()=>"青岛";
}

class Child1 extends OtherPerson with Person001,Person002 {

  @override
  String getPhone() {
    // TODO: implement getPhone
    print('child 1 1');
  }

  @override
  String getCity() {
    // TODO: implement getCity
    print('city child 11 ');
  }

}

class Child2 extends OtherPerson with Person001, Person002 { }
print('------------minxins-----------Start');

      Child1 c1 = Child1();
      print(c1.getPhone());//Child1   iphone  重写了函数,调用时用的是自身的函数
      print(c1.getCity());//Child1  oriange   重写了函数,调用时用的是自身的函数
      print(c1.getDesk());//333   调用的是OtherPerson的函数  person1 person2中没有同名函数
      print(c1.getNum());//6  调用的是person2中的函数
      print(c1.getAddress());//person1 历下区 调用的是person1中的函数
      print(c1.getColor());//person2  2 red  调用的是person2中的函数
      print(c1.getName());//person2  wei2 调用的是person2中的函数    person2在声明顺序中更靠后



      print("-----------------------");
      Child2 c2 = Child2();
      print(c2.getPhone());//OtherPerson  123  没有重写函数,调用时用的是OtherPerson的函数
      print(c2.getCity());//济南   没有重写函数,调用时用的是person2的函数,虽然OtherPerson也有,但person2在声明顺序中更靠后
      print(c2.getDesk());//333     调用的是OtherPerson的函数  person1 person2中没有同名函数
      print(c2.getNum());//6     调用的是person2中的函数
      print(c2.getAddress());//历下区   调用的是Person1中的函数
      print(c2.getColor());//2   red      调用的是Person2中的函数
      print(c2.getName());//wei2      调用的是Person2中的函数   Person1在声明顺序中更靠后

      print('------------minxins-----------end');

理解:

  1. A extends B with C,D{}
  2. A 继承了B 并拥有了C和D所有的属性和函数,可以用A的实例直接调用CD的属性方法。
  3. 如果B有函数fun1,A重写了这个函数 那么以后A的实例调用的fun1,都是A重写后的方法。
  4. 如果B有函数fun1,CD中也有函数fun1,A重写了这个函数 那么以后A的实例调用的fun1,都是A重写后的方法。
  5. 如果B有函数fun1,CD中也有函数fun1,A没有重写这个函数 那么以后A的实例调用的fun1,是声明方法时最后的那个类的函数,比如“A extends B with C,D”,那么就是D中的fun1,如果是“A extends B with D,C”,那么就是C中的fun1。也就是说优先级是从后向前的(前提是子类没有重写函数)。
  6. 和Python中装饰器是一样的

参考: https://www.jianshu.com/p/232271ad2768

上一篇 下一篇

猜你喜欢

热点阅读