dart系列之:你的地盘你做主,使用Extension对类进行扩展

简介: dart系列之:你的地盘你做主,使用Extension对类进行扩展

目录



简介


一般情况要扩展一个类,需要继承这个类,这是在大多数java或者其他面向对象语言中要做的事情。


但是有些时候扩展类并不是特别好用,首先在有些语言中,有些类是禁止被扩展的。即使可以被扩展,但是扩展之后的类是一个新的类,而不是原来的父类,所以在使用的过程中可能会出现一些类型转换的问题。


那么在dart中是怎么解决这个问题的呢?


dart中extension的使用


dart在2.7之后,引入了extension,用来对类的方法进行扩展。


到底怎么扩展呢?我们举个例子.


我们可以将字符串转换为int,通过调用int的parse方法,如下所示:


int.parse('18')


但是通过int类来进行转换通常不太直观,我们希望能够在String类中提供一个toInt的方法,可以直接调用,将字符串转换成为int。


'18'.toInt()


但是很遗憾,String并没有提供toInt的方法,所以我们可以通过extension来对String进行扩展:


extension StringToNumber on String {
  int toInt() {
    return int.parse(this);
  }
  // ···
}


如果这个文件的名字叫做string_to_number.dart,那么我们可以这样使用:


import 'string_to_number.dart';
// ···
print('18'.parseInt());


dart中方法扩展最为方便的是,你只要引入对应的lib,使用的时候甚至都不知道在使用lib的扩展。


当然,并不是所有的类都可以使用extention进行扩展。比如dynamic类型就不能进行扩展。


但是使用var类型,只要该类型可以被推断出来,那么就可以使用extention扩展。


API冲突


既然可以对lib进行扩展,那么就有可能出现API冲突的情况。那么怎么解决API冲突呢?


比如我们需要使用两个lib扩展文件,extention1.dart和extention2.dart.但是两个扩展文件中都定义了parseInt方法对String进行扩展。


如果同时引用的话,就会出现问题。


这时候可以使用show或者hide来限制具体使用哪一个扩展文件的中的方法。


import 'extention1.dart';
import 'extention2.dart' hide StringToNumber2;
print('18'.parseInt());


还有一种情况就是显示调用extension,如下所示:


import 'extention1.dart';
import 'extention2.dart';
print(StringToNumber('18').parseInt());
print(StringToNumber2('18').parseInt());


通过extention的名字来进行区分。


如果两个extention的名字也相同的话,那么可以通过prefix来进行区分:


import 'extention1.dart';
import 'extention2.dart' as ext2;
print(StringToNumber('18').parseInt());
print(ext2.StringToNumber('18').parseInt());


extention的实现


实现扩展很简单,实现语法如下:


extension <extension name> on <type> {
  (<member definition>)*
}


下面是一个扩展String的例子:


extension NumberParsing on String {
  int parseInt() {
    return int.parse(this);
  }
  double parseDouble() {
    return double.parse(this);
  }
}


extension还可以扩展泛型参数:


extension MyFancyList<T> on List<T> {
  int get doubleLength => length * 2;
  List<T> operator -() => reversed.toList();
  List<List<T>> split(int at) => [sublist(0, at), sublist(at)];
}


上面的实现是对List 进行扩展,添加了getter,操作符和split方法。


总结



以上就是2.7的新特性,类的扩展。

相关文章
|
3月前
|
固态存储 内存技术 NoSQL
基础代码NVMe模块的实例helloworld代码
基础代码NVMe模块的实例helloworld代码
|
2月前
|
存储 XML Java
探索Java常用的包:从核心到扩展
探索Java常用的包:从核心到扩展
37 3
|
2月前
一篇文章讲明白jav8特性特性应用
一篇文章讲明白jav8特性特性应用
136 0
|
3月前
|
设计模式 Oracle 关系型数据库
二十三种设计模式全面解析-适配器模式的妙用:异构数据库和不同版本API的完美兼容!
二十三种设计模式全面解析-适配器模式的妙用:异构数据库和不同版本API的完美兼容!
|
安全 Java 程序员
java面向对象的三大特性之封装和继承(配视频讲解)
🍅程序员小王的博客:程序员小王的博客 🍅程序员小王的资源博客:http://wanghj.online/ 🍅 欢迎点赞 👍 收藏 ⭐留言 📝 🍅 如有编辑错误联系作者,如果有比较好的文章欢迎分享给我,我会取其精华去其糟粕 🍅java自学的学习路线:java自学的学习路线 ———————————————— 版权声明:本文为CSDN博主「程序员小王java」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/weixin_44385486/article/details/128171102
147 0
java面向对象的三大特性之封装和继承(配视频讲解)
【Groovy】MOP 元对象协议与元编程 ( Expando 动态类 | 创建动态类 | 为动态类增加字段和方法 )
【Groovy】MOP 元对象协议与元编程 ( Expando 动态类 | 创建动态类 | 为动态类增加字段和方法 )
171 0
【Groovy】MOP 元对象协议与元编程 ( Expando 动态类 | 创建动态类 | 为动态类增加字段和方法 )
|
Kotlin
【Kotlin】扩展接收者 与 分发接收者 ( 类内部扩展用法 | 注意事项 | open 修饰扩展 )
【Kotlin】扩展接收者 与 分发接收者 ( 类内部扩展用法 | 注意事项 | open 修饰扩展 )
168 0
【Kotlin】扩展接收者 与 分发接收者 ( 类内部扩展用法 | 注意事项 | open 修饰扩展 )
升级版的工厂模式(外联配置文件+内用反射),体现多态好处(^-^)
升级版的工厂模式(外联配置文件+内用反射),体现多态好处(^-^)
94 0
|
C# 图形学 Windows
原生实现C#和Lua相互调用-Unity3D可用【中】
1. 编译Windows下使用的DLL文件 使用VS2015创建一个空的动态链接库项目,删除里面默认创建的几个文件(如果想自定义拓展可用保留),然后把Lua的源码拷贝进来,添加到项目工程中,编译宏需要配置LUA_BUILD_AS_DLL和_CRT_SECURE_NO_WARNINGS。然后就可以编译x86和x64的DLL动态库,整体步骤简单易操作。
183 0
|
API C# Android开发
原生实现C#和Lua相互调用-Unity3D可用【上】
1. 编译Windows下使用的DLL文件 使用VS2015创建一个空的动态链接库项目,删除里面默认创建的几个文件(如果想自定义拓展可用保留),然后把Lua的源码拷贝进来,添加到项目工程中,编译宏需要配置LUA_BUILD_AS_DLL和_CRT_SECURE_NO_WARNINGS。然后就可以编译x86和x64的DLL动态库,整体步骤简单易操作。
301 0