当前位置: 首页 > news >正文

电商网站充值消费系统网站建设的题目

电商网站充值消费系统,网站建设的题目,湘潭网站建设定制磐石网络,爱旅游网站制作0 说明 该系列教程主要是为有一定语言基础 C/C的程序员,快速学习一门新语言所采用的方法,属于在C/C基础上扩展新语言的模式。 1 async和await 在Dart语言中,虽然没有像其他语言(如Java、C、Python)中的传统多线程概…

0 说明

该系列教程主要是为有一定语言基础 C/C++的程序员,快速学习一门新语言所采用的方法,属于在C/C++基础上扩展新语言的模式。

1 async和await

在Dart语言中,虽然没有像其他语言(如Java、C++、Python)中的传统多线程概念,但它采用了异步(asynchronous)编程模型来处理并发任务。Dart使用async和await关键字来支持异步操作,这可以在很大程度上达到类似多线程的效果,但实际上是基于单线程的事件循环机制。

异步主要涉及2个关键词:async和await。async 是让方法变成异步,await是等待异步方法执行完。两个关键字的约束如下:

  • 只有async方法才能使用await关键字去调用方法。
  • 如果调用别的async方法必须使用await关键字。

这里以一个http服务为例来解读这两个关键字的使用,代码如下所示:

import 'dart:convert';
import 'package:http/http.dart' as http;void main() async {// 发起HTTP GET请求final response = await http.get(Uri.parse('https://jsonplaceholder.typicode.com/posts/1'));if (response.statusCode == 200) {final responseData = json.decode(response.body);print('Title: ${responseData['title']}');print('Body: ${responseData['body']}');} else {print('Request failed with status: ${response.statusCode}');}
}

2 隔离 Isolate机制

在Dart中本身是没有多进程概念的,但可以使用Isolate隔离机制来实现多进程效果。Isolate是一种轻量级的并发执行单元,可以在不同的线程中运行代码(说明:每个isolate 都有一个完整的事件循环机制,每个隔离区都有自己的内存堆,确保每个隔离区的状态都不会被其他隔离区访问,隔离这种机制更像是进城而非线程)。这里制作一个demo,模拟 主线程循环输出aaa,子线程循环输出bbb,各输出5次,代码实现如下所示:

import 'dart:isolate';void main() {startChildIsolate();for (var i = 0; i < 5; i++) {print("aaa");sleep(Duration(seconds: 1));}
}void startChildIsolate() async {final isolate = await Isolate.spawn(childIsolate, null);
}void childIsolate(dynamic message) {for (var i = 0; i < 5; i++) {print("bbb");sleep(Duration(seconds: 1));}
}

命令执行效果如下所示:

Connecting to VM Service at ws://127.0.0.1:59390/qHZyzE0WjeQ=/ws
aaa
bbb
aaa
bbb
aaa
bbb
aaa
bbb
---------

3 Isolate 隔离-双向通讯

这里主要通过Isolate机制构建了一个主线程和一个子线程并进行双向通信,主要使用SendPort和ReceivePort。代码实现如下:

import 'dart:isolate';var anotherIsolate;void startMainIsolate() async {var receivePort = ReceivePort();var sendPort;anotherIsolate = await Isolate.spawn(threadIsolateInit, receivePort.sendPort);receivePort.listen((date) {if (date is SendPort) {sendPort = date;print("双向通讯建立成功");return;}print("主线程 接收消息:data = $date");sendPort.send("XXXXX");});
}void threadIsolateInit(SendPort sendPort) async {var receivePort = ReceivePort();print("子线程 接受到来自 主线程的port,尝试建立同主线程的双向通讯");receivePort.listen((date) {print("子线程接收消息:data = $date");});sendPort.send(receivePort.sendPort);for (var index = 0; index < 10; index++) {sendPort.send("子线程 发送消息:$index");}
}void main() {startMainIsolate();
}

运行效果如下:

onnecting to VM Service at ws://127.0.0.1:60037/CvPyFfwECy8=/ws
子线程 接受到来自 主线程的port,尝试建立同主线程的双向通讯
双向通讯建立成功
主线程 接收消息:data = 子线程 发送消息:0
主线程 接收消息:data = 子线程 发送消息:1
主线程 接收消息:data = 子线程 发送消息:2
主线程 接收消息:data = 子线程 发送消息:3
子线程接收消息:data = XXXXX
主线程 接收消息:data = 子线程 发送消息:4
子线程接收消息:data = XXXXX
主线程 接收消息:data = 子线程 发送消息:5
子线程接收消息:data = XXXXX
主线程 接收消息:data = 子线程 发送消息:6
子线程接收消息:data = XXXXX
主线程 接收消息:data = 子线程 发送消息:7
子线程接收消息:data = XXXXX
主线程 接收消息:data = 子线程 发送消息:8
子线程接收消息:data = XXXXX
主线程 接收消息:data = 子线程 发送消息:9
子线程接收消息:data = XXXXX
子线程接收消息:data = XXXXX
子线程接收消息:data = XXXXX
子线程接收消息:data = XXXXX

http://www.yayakq.cn/news/787339/

相关文章:

  • 坪山网站建设公司建筑专业网站有哪些
  • 山西省建设工程网站网站建设重要
  • 手机网站建设可信赖营销策略ppt模板
  • 租凭境外服务器做违规网站三维家软件培训班
  • 酒店预订网站建设图片网站建设方案
  • 免费视频素材网站都有哪些网络营销推广方法和手段
  • 备案网站免网泉州网站建设多少钱
  • c 网站开发案例详解湘潭网站建设电话
  • 云邦北京网站建设超级门户博客版wordpress主题
  • 陕西 网站备案企业网络营销策划案例
  • 公司网站建设情况说明书网站外包如何报价
  • 自己做qq代刷网站要钱吗wordpress wampserve
  • 如皋网站定制如何分析一个网站开发语言
  • 个人网站备案容易吗电子商务网站推广的主要方法
  • 建设银行信用卡官方网站网上商城网站开发与建立的意义
  • 网站推广的基本方法是网站域名.xin
  • 网站jquery在线优化网页设计培训好学吗
  • 免费的微信小程序徐州关键字优化公司
  • 网站上传的工具推广系统建站
  • wamp做的网站标签图标中石化两学一做网站
  • 网站登记表网站删除关键词
  • 做网站有什么专业术语合肥网站建设哪家好
  • 高清做网站插图云南网站优化排名
  • 建设网站前需要的市场分析网站改版了
  • 网站做百度推广需要什么材料婚车租赁
  • 上海网站建设制作公司网站建设项目安排计划表
  • 网站建设公司如何签单网站一年续费多少钱
  • 中小企业网站制作流程外贸网站怎么做
  • 生活常识网站源码vps 网站 需要绑定域名吗
  • 攀枝花建设集团网站亚马逊网站联盟