- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
当我尝试调用 listenEventReducer
时,出现了这个奇怪的错误。该方法知道类型,但仍然不确定我哪里出错了。
import 'package:test/test.dart';
enum ObjectChangeType { added, modified, removed }
typedef UpdateItem<T extends ListenEventItem> = T Function(T oldItem, T newItem);
T _defaultUpdate<T extends ListenEventItem>(T oldItem, T newItem) => newItem;
abstract class ListenEventItem {
String get id;
ObjectChangeType get changeType;
}
abstract class ListenEvent<T extends ListenEventItem> {
List<T> get data;
Map<ObjectChangeType, List<T>> get typedData {
return data.fold(
<ObjectChangeType, List<T>>{},
(Map<ObjectChangeType, List<T>> map, T element) {
map[element.changeType] = (map[element.changeType] ?? <T>[])..add(element);
return map;
},
);
}
}
Map<String, T> listenEventReducer<T extends ListenEventItem>(Map<String, T> state, ListenEvent<T> action,
[UpdateItem<T> update = _defaultUpdate]) {
update ??= _defaultUpdate;
final Map<String, T> b = Map<String, T>.from(state);
for (ObjectChangeType type in ObjectChangeType.values) {
final List<T> data = action.typedData[type];
if (data == null || data.isEmpty) {
continue;
}
if (type == ObjectChangeType.added) {
for (T item in data) {
b[item.id] == item;
}
} else if (type == ObjectChangeType.modified) {
for (T item in data) {
b[item.id] = update(b[item.id], item);
}
} else if (type == ObjectChangeType.removed) {
final List<String> ids = data.map((T it) => it.id).toList();
b.removeWhere((String id, _) => ids.contains(id));
}
}
return b;
}
class Data extends ListenEventItem {
Data(this.id, this.changeType, this.metadata);
final String metadata;
@override
final String id;
@override
final ObjectChangeType changeType;
}
class DataEvent extends ListenEvent<Data> {
DataEvent(this.data);
@override
final List<Data> data;
}
void main() {
final List<Data> items = List<Data>();
items.add(Data('0', ObjectChangeType.added, 'a'));
items.add(Data('1', ObjectChangeType.added, 'b'));
items.add(Data('0', ObjectChangeType.removed, 'a'));
items.add(Data('2', ObjectChangeType.added, 'c'));
items.add(Data('1', ObjectChangeType.modified, 'd'));
items.add(Data('3', ObjectChangeType.added, 'e'));
final DataEvent event = DataEvent(items);
final Map<String, Data> state = Map<String, Data>();
final Map<String, Data> newState = listenEventReducer<Data>(state, event);
expect(newState, isNotNull);
expect(newState.length, 3);
expect(newState['0'], isNull);
expect(newState['1'].metadata, 'd');
expect(newState['2'].metadata, 'c');
expect(newState['3'].metadata, 'e');
}
最佳答案
问题是 typedef
和函数类型 _defaultUpdate
不完全匹配并向编译器提供有关类型泛型的完整信息。
初始化时[UpdateItem<T> update = _defaultUpdate]
,编译器需要类型 T
对于 UpdateItem 但它不知道是否 _defaultUpdate
实际上正在返回 T
其中 T extends ListenEventItem
, _defaultUpdate
可以返回任何类型 S
其中 S extends ListenEventItem
.
例如,假设您有两个扩展 ListenEventItem
的类
class A extends ListenEventItem {}
和
class B extends ListenEventItem {}
现在,_defaultUpdate
函数可以返回 A
或 B
当没有传递通用参数时。当你尝试像这样初始化它时
UpdateItem<A> update = _defaultUpdate
编译器不知道是否 _defaultUpdate
返回 A
或 B
使其在编译时失败。
您可以修复此问题,使 typedef 函数接受通用参数,这样编译器就知道期望任何扩展 ListenEventItem
的类
例子:
typedef UpdateItem = T Function<T extends ListenEventItem>(T oldItem, T newItem);
T _defaultUpdate<T extends ListenEventItem>(T oldItem, T newItem) => newItem;
完整代码:
import 'package:test/test.dart';
enum ObjectChangeType { added, modified, removed }
typedef UpdateItem = T Function<T extends ListenEventItem>(T oldItem, T newItem);
T _defaultUpdate<T extends ListenEventItem>(T oldItem, T newItem) => newItem;
abstract class ListenEventItem {
String get id;
ObjectChangeType get changeType;
}
abstract class ListenEvent<T extends ListenEventItem> {
List<T> get data;
Map<ObjectChangeType, List<T>> get typedData {
return data.fold(
<ObjectChangeType, List<T>>{},
(Map<ObjectChangeType, List<T>> map, T element) {
map[element.changeType] = (map[element.changeType] ?? <T>[])
..add(element);
return map;
},
);
}
}
Map<String, T> listenEventReducer<T extends ListenEventItem>(
Map<String, T> state, ListenEvent<T> action,
[UpdateItem update = _defaultUpdate]) {
update ??= _defaultUpdate;
final Map<String, T> b = Map<String, T>.from(state);
for (ObjectChangeType type in ObjectChangeType.values) {
final List<T> data = action.typedData[type];
if (data == null || data.isEmpty) {
continue;
}
if (type == ObjectChangeType.added) {
for (T item in data) {
b[item.id] = item;
}
} else if (type == ObjectChangeType.modified) {
for (T item in data) {
b[item.id] = update(b[item.id], item);
}
} else if (type == ObjectChangeType.removed) {
final List<String> ids = data.map((T it) => it.id).toList();
b.removeWhere((String id, _) => ids.contains(id));
}
}
return b;
}
class Data extends ListenEventItem {
Data(this.id, this.changeType, this.metadata);
final String metadata;
@override
final String id;
@override
final ObjectChangeType changeType;
}
class DataEvent extends ListenEvent<Data> {
DataEvent(this.data);
@override
final List<Data> data;
}
void main() {
final List<Data> items = List<Data>();
items.add(Data('0', ObjectChangeType.added, 'a'));
items.add(Data('1', ObjectChangeType.added, 'b'));
items.add(Data('0', ObjectChangeType.removed, 'a'));
items.add(Data('2', ObjectChangeType.added, 'c'));
items.add(Data('1', ObjectChangeType.modified, 'd'));
items.add(Data('3', ObjectChangeType.added, 'e'));
final DataEvent event = DataEvent(items);
final Map<String, Data> state = Map<String, Data>();
final Map<String, Data> newState = listenEventReducer<Data>(state, event);
test('Test', () {
expect(newState, isNotNull);
expect(newState.length, 3);
expect(newState['0'], isNull);
expect(newState['1'].metadata, 'd');
expect(newState['2'].metadata, 'c');
expect(newState['3'].metadata, 'e');
});
}
关于flutter - 编译时间错误 : Type arguments in partial instantiations must be instantiated and are therefore not allowed to depend on type parameters,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57051480/
我正在 Angular js和sails.js(node.js框架)之间的cors问题上挣扎 我尝试修复错误:XMLHttpRequest无法加载http://localhost:1337/en/au
我在我的应用程序中动态创建一个 iframe,结果如下所示: 这样的沙箱配置是否安全(特别是允许将 iframe 内容视为来自同一来源)? 最佳答案 正如 Namey 评论的那样,allow-sam
突然,似乎没有更改我的网络应用程序中的任何内容,我在 Chrome 中打开它时开始收到 CORS 错误。我尝试添加 Access-Control-Allow-Origin: *标题。然后我得到这个错误
我正在使用 Ionic Framework 开发应用程序。 在后端,我为 api 编写了一个 Flask 应用程序,如下所示: @API.route("/saverez",methods=["POST
我正在尝试从 onesignal api 发送 POST 请求 代码 axios({ method: 'post', url: 'https://onesignal.com/api/v1/no
我一直在寻找一些类似的问题来寻找答案,但我找不到。我有一个带有 express 的 node.js 服务器: app.use(function(req, res, next) { res.head
我使用 Google Cloud Functions 创建了一个 API 端点,并试图从 JS 获取函数中调用它。 我遇到了我很确定与 CORS 或输出格式有关的错误,但我不确定发生了什么。其他一些
当我尝试从我的 Angular 6 应用程序访问 Webhdfs 时,我收到如下所示的错误。在我看来,我几乎尝试了所有方法,包括更改 core-site.xml 和 hdfs-site.xml 中的设
我刚刚学习 ajax 和 cors 一些东西,现在我想知道 chrome 插件“allow-control-allow-origin”是如何工作的。 当我尝试执行正常的 ajax 请求时,控制台显示错
我正在努力理解如何允许用户在列表中创建新记录,但只允许创建者更新他们自己的帖子。 例如。以下结构: post { post1: { author: "user1"
我们的网络上有 2 个内部(内联网)Windows 服务器,仅适用于本地网络。在 server1 上安装了 Spark,我们可以在其中查询 Jabber 信息,如下所示: http://server1
所以在 routing.yml 中我定义了以下路由,以便编辑和删除特定设置: 路由.yml: settings.editDefaults: path: settings/{id}/d
我哪里出错了 title $.get("http://api.angel.co/1/tags/1654/startups?callback=aaa", function(data
首先,对您可能犯的语法错误表示歉意。我的英语不是很好。 我是 Spring 新手,我正在尝试创建基本身份验证安全性。 我正在尝试配置一个端点具有公共(public)访问权限,而其他端点则具有用户访问权
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: NULL in MySQL (Performance & Storage) 如果出现以下情况,您是否强烈建议取消选中
我正在尝试将我的一个网站中的内容加载到另一个网站中: $('#include-from-outside').load('http://lujanventas.com/plugins/banne
这里出了什么问题? OPTIONS https://twitter.com/oauth/request_token 401 (Unauthorized) jsOAuth-1.3.4.js:483 XM
allow-control-allow-origin : * header 存在于 API 响应中,但浏览器仍显示错误。网络 403 错误。 这是来自 API 的示例响应 header : Acces
在 Go 中制作 slice 时的 capacity 参数对我来说意义不大。例如, aSlice := make([]int, 2, 2) //a new slice with length and
Gitlab 保护分支中“允许推送”和“允许 merge ”是什么意思 最佳答案 引用 Gitlab Documentation here Using the "Allowed to push" an
我是一名优秀的程序员,十分优秀!