(六)启动方式

下的launchMode属性可以设置四种启动方式:

"standard" (the default mode)

"singleTop"

"singleTask"

"singleInstance"

这些不同的方式可以从下面的四点来说:

(1)对一个Intent作出回应时哪个task应该去持有这个Activity。

对standard和singleTop方式来说,新的Activity和通过startActivity调用他的Activity处在同一个task 中,如果调用时Intent对象里含有FLAG_ACTIVITY_NEW_TASK标志,那么就像前面讲的那样的寻找一个新的task。

相反的,singTask和singleInstance方式,总是标志Activity为task的root Activity,他们不会进入到其他的task中。

(2)一个Activity是否可以有多个实例。

一个standard或者singleTop属性的Activity可以实例化多次,他们可以属于多个不同的task。

相反的,singleTask或者singleInstance属性的Activity只能有一个实例(单例)。

(3)实例是否能允许在task里有其他的Activity。

一个singleInstance属性的Activity单独的在他自己的task里,并且这个task里只能有他自己一个Activity,如果他启 动了另一个Activity,那个Activity会根据启动模式来启动并装进一个不同的task里。其他的方面,singleInstance和 singleTask一样的。

其他三个方式允许有多个Activity在一个task里,一个singleTask属性的 Activity总是一个task里的root Activity,但是他可以启动另外的Activity并且将这个新的Activity装进同一个task里,standard和singleTop属 性的Activity可以出现在task的任何地方。

(4)一个类(Activity)的对象是否可以被启动来处理一个新的Intent。

对默认的standard方式,会实例化一个对象来处理每一个新的Intent,每个实例处理一个新的Intent,对singleTop方式,如果一 个已经存在的实例是在task的栈顶,那么就重用这个实例来处理这个新的Intent,如果这个实例不在栈顶,那就不复用他,而是重新创建一个实例来处理 这个新的Intent并且将这个实例压入堆栈。

例如现在有一个task堆栈ABCD,A是root Activity,D是栈顶Activity,现在有一个启动D的Intent来了,如果D是默认的standard方法,那么就会创建一个新的实例来处 理这个Intent,所以这个堆栈就变为ABCDD,然而如果D是singleTop方式,这个已经存在的栈顶的D就会来处理这个Intent,所以堆栈 还是ABCD。D此时调用onNewIntent(),此时D可以调用getIntent()来获得最初的Intent,或者调用setIntent() 来更新这个Intent。

如果现在有一个Intent来启动B,不管B是standard还是singleTop(因为现在B不在栈顶),都会创建一个新的实例,所以堆栈变为ABCDB

在一个task里,对singleTask和singleInstance属性的Activity只能有一个实例。所以这仅有的一个会来处理所以的 Intent,一个singleInstance属性Activity总在栈顶(因为task里就只有他一个Activity),所以他会处理所以的 Intent,但是一个singleTask属性的Activity必须是task的root Activity(也就是必须在栈底),不能确定他的上面是否还有其他的Activity,如果没有,就可以处理,如果还有其他的Activity,那么 如果现在有一个Intent来启动这个singleTask属性的Activity,这个Intent将会被丢掉(即使是这个Intent被丢掉,他的到 来还是会导致这个task回到前台)。

当创建一个类(Activity)的实例来处理一个新的Intent时,用户可以按下BACK键 回到上一个Activity,但是如果是用已经存在的栈顶的Activity来处理Intent的话,按下BACK键是不能回到以前的状态的(没处理这个 Intent之前)。

内容概要:本文详细介绍了基于FPGA的144输出通道可切换电压源系统的设计与实现,涵盖系统总体架构、FPGA硬件设计、上位机软件设计以及系统集成方案。系统由上位机控制软件(PC端)、FPGA控制核心和高压输出模块(144通道)三部分组成。FPGA硬件设计部分详细描述了Verilog代码实现,包括PWM生成模块、UART通信模块和温度监控模块。硬件设计说明中提及了FPGA选型、PWM生成方式、通信接口、高压输出模块和保护电路的设计要点。上位机软件采用Python编写,实现了设备连接、命令发送、序列控制等功能,并提供了一个图形用户界面(GUI)用于方便的操作和配置。 适合人群:具备一定硬件设计和编程基础的电子工程师、FPGA开发者及科研人员。 使用场景及目标:①适用于需要精确控制多通道电压输出的实验环境或工业应用场景;②帮助用户理解和掌握FPGA在复杂控制系统中的应用,包括PWM控制、UART通信及多通道信号处理;③为研究人员提供一个可扩展的平台,用于测试和验证不同的电压源控制算法和策略。 阅读建议:由于涉及硬件和软件两方面的内容,建议读者先熟悉FPGA基础知识和Verilog语言,同时具备一定的Python编程经验。在阅读过程中,应结合硬件电路图和代码注释,逐步理解系统的各个组成部分及其相互关系。此外,实际动手搭建和调试该系统将有助于加深对整个设计的理解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值