当前位置: 首页 > 文档资料 > Dart 中文教程 >

dart 类 Classes

优质
小牛编辑
134浏览
2023-12-01

Dart是一种面向对象的语言。 它支持面向对象的编程功能,如类,接口等.OOP方面的class是创建对象的蓝图。 class封装了对象的数据。 Dart为这个名为class概念提供了内置支持。

宣布一个class

使用class关键字在Dart中声明一个class 。 类定义以关键字class开头,后跟class name ; 并且由一对花括号包围的类体。 下面给出了相同的语法 -

语法 (Syntax)

class class_name {  
   <fields> 
   <getters/setters> 
   <constructors> 
   <functions> 
}

class关键字后跟类名。 在命名类时必须考虑标识符的规则。

类定义可包括以下内容 -

  • Fields - 字段是类中声明的任何变量。 字段表示与对象有关的数据。

  • Setters and Getters - 允许程序初始化和检索类字段的值。 默认的getter/setter与每个类相关联。 但是,可以通过显式定义setter/getter来覆盖默认值。

  • Constructors - 负责为类的对象分配内存。

  • Functions - 函数表示对象可以采取的操作。 它们有时也被称为方法。

这些组件放在一起称为该类的data members

示例:声明一个类

class Car {  
   // field 
   String engine = "E1001";  
   // function 
   void disp() { 
      print(engine); 
   } 
}

该示例声明了一个类Car 。 该类有一个名为engine的字段。 disp()是一个打印字段engine值的简单函数。

创建类的实例

要创建类的实例,请使用new关键字,后跟类名。 下面给出了相同的语法 -

语法 (Syntax)

var object_name = new class_name([ arguments ])
  • new关键字负责实例化。

  • 表达式的右侧调用构造函数。 如果参数化,构造函数应该传递值。

示例:实例化一个类

var obj = new Car("Engine 1")

访问属性和函数 (Accessing Attributes and Functions)

可以通过对象访问类的属性和函数。 使用 '。' 用于访问类的数据成员的点表示法(称为period )。

//accessing an attribute 
obj.field_name  
//accessing a function 
obj.function_name()

例子 (Example)

请看下面的示例,了解如何在Dart中访问属性和函数 -

void main() { 
   Car c= new Car(); 
   c.disp(); 
}  
class Car {  
   // field 
   String engine = "E1001";  
   // function 
   void disp() { 
      print(engine); 
   } 
}

上述代码的output如下 -

E1001

Dart_programming构造师

构造函数是类的特殊函数,负责初始化类的变量。 Dart定义了一个与该类名称相同的构造函数。 构造函数是一个函数,因此可以参数化。 但是,与函数不同,构造函数不能具有返回类型。 如果未声明构造函数,则会为您提供默认的no-argument constructor

语法 (Syntax)

Class_name(parameter_list) { 
   //constructor body 
}

例子 (Example)

以下示例显示如何在Dart中使用构造函数 -

void main() { 
   Car c = new Car('E1001'); 
} 
class Car { 
   Car(String engine) { 
      print(engine); 
   } 
}

它应该产生以下output -

E1001 

命名的构造函数

Dart提供了named constructors以使类定义multiple constructors 。 命名构造函数的语法如下所示 -

语法:定义构造函数

Class_name.constructor_name(param_list)

例子 (Example)

以下示例显示如何在Dart中使用命名构造函数 -

void main() {           
   Car c1 = new Car.namedConst('E1001');                                       
   Car c2 = new Car(); 
}           
class Car {                   
   Car() {                           
      print("Non-parameterized constructor invoked");
   }                                   
   Car.namedConst(String engine) { 
      print("The engine is : ${engine}");    
   }                               
}

它应该产生以下output -

The engine is : E1001 
Non-parameterized constructor invoked

这个关键字

this关键字引用类的当前实例。 这里,参数名称和类字段的名称是相同的。 因此,为了避免歧义,类的字段以this关键字为前缀。 以下示例解释相同 -

例子 (Example)

以下示例说明如何在Dart中使用this关键字 -

void main() { 
   Car c1 = new Car('E1001'); 
}  
class Car { 
   String engine; 
   Car(String engine) { 
      this.engine = engine; 
      print("The engine is : ${engine}"); 
   } 
} 

它应该产生以下output -

The engine is : E1001

Dart_programming类─吸气员和二传手

GettersSetters ,也称为accessors mutators和更改mutators ,允许程序分别初始化和检索类字段的值。 使用get关键字定义getter或访问器。 Setter或mutator是使用set关键字定义的。

默认的getter/setter与每个类相关联。 但是,可以通过显式定义setter/getter来覆盖默认值。 getter没有参数并返回一个值,setter有一个参数并且不返回值。

语法:定义一个getter

Return_type  get identifier 
{ 
} 

语法:定义一个setter

set identifier 
{ 
}

例子 (Example)

以下示例显示如何在Dart类中使用getterssetters -

class Student { 
   String name; 
   int age; 
   String get stud_name { 
      return name; 
   } 
   void set stud_name(String name) { 
      this.name = name; 
   } 
   void set stud_age(int age) { 
      if(age<= 0) { 
        print("Age should be greater than 5"); 
      }  else { 
         this.age = age; 
      } 
   } 
   int get stud_age { 
      return age;     
   } 
}  
void main() { 
   Student s1 = new Student(); 
   s1.stud_name = 'MARK'; 
   s1.stud_age = 0; 
   print(s1.stud_name); 
   print(s1.stud_age); 
} 

该程序代码应产生以下output -

Age should be greater than 5 
MARK 
Null 

类继承

Dart支持继承的概念,这是程序从现有类创建新类的能力。 扩展为创建较新类的类称为父类/超类。 新创建的类称为子/子类。

一个类使用'extends'关键字从另一个类继承。 Child classes inherit all properties and methods except constructors from the parent class

语法 (Syntax)

class child_class_name extends parent_class_name 

Note - Dart不支持多重继承。

示例:类继承

在以下示例中,我们声明了一个类Shape 。 该类由Circle类扩展。 由于类之间存在继承关系,因此子类(即Car类)获得对其父类数据成员的隐式访问。

void main() { 
   var obj = new Circle(); 
   obj.cal_area(); 
}  
class Shape { 
   void cal_area() { 
      print("calling calc area defined in the Shape class"); 
   } 
}  
class Circle extends Shape {}

它应该产生以下output -

calling calc area defined in the Shape class

继承的类型

继承可以是以下三种类型 -

  • Single - 每个类最多可以从一个父类扩展。

  • Multiple - 一个类可以从多个类继承。 Dart不支持多重继承。

  • Multi-level - 类可以从另一个子类继承。

例子 (Example)

以下示例显示了多级继承的工作原理 -

void main() { 
   var obj = new Leaf(); 
   obj.str = "hello"; 
   print(obj.str); 
}  
class Root { 
   String str; 
}  
class Child extends Root {}  
class Leaf extends Child {}  
//indirectly inherits from Root by virtue of inheritance

Leaf类通过多级继承从Root类和Child类派生属性。 其output如下 -

hello

Dart - 类继承和方法重写

方法重写是子类在其父类中重新定义方法的机制。 以下示例说明了相同的情况 -

例子 (Example)

void main() { 
   Child c = new Child(); 
   c.m1(12); 
} 
class Parent { 
   void m1(int a){ print("value of a ${a}");} 
}  
class Child extends Parent { 
   @override 
   void m1(int b) { 
      print("value of b ${b}"); 
   } 
}

它应该产生以下output -

value of b 12

重写方法时,函数参数的数量和类型必须匹配。 如果参数数量或其数据类型不匹配,Dart编译器会抛出错误。 下图说明了相同的 -

import 'dart:io'; 
void main() { 
   Child c = new Child(); 
   c.m1(12); 
} 
class Parent { 
   void m1(int a){ print("value of a ${a}");} 
} 
class Child extends Parent { 
   @override 
   void m1(String b) { 
      print("value of b ${b}");
   } 
}

它应该产生以下output -

value of b 12

静态关键字

static关键字可以应用于类的数据成员,即fieldsmethods 。 静态变量保留其值,直到程序完成执行。 静态成员由类名引用。

例子 (Example)

class StaticMem { 
   static int num;  
   static disp() { 
      print("The value of num is ${StaticMem.num}")  ; 
   } 
}  
void main() { 
   StaticMem.num = 12;  
   // initialize the static variable } 
   StaticMem.disp();   
   // invoke the static method 
}

它应该产生以下output -

The value of num is 12

超级关键字

super关键字用于指代类的直接父级。 关键字可用于引用variable, property,method的超类版本。 以下示例说明了相同的情况 -

例子 (Example)

void main() { 
   Child c = new Child(); 
   c.m1(12); 
} 
class Parent { 
   String msg = "message variable from the parent class"; 
   void m1(int a){ print("value of a ${a}");} 
} 
class Child extends Parent { 
   @override 
   void m1(int b) { 
      print("value of b ${b}"); 
      super.m1(13); 
      print("${super.msg}")   ; 
   } 
}

它应该产生以下output -

value of b 12 
value of a 13 
message variable from the parent class