首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

《假如编程是魔法之零基础看得懂的Python入门教程 》——(五)我的魔法竟然有了一丝逻辑

在python中进行逻辑判断其实指的是流程控制,那什么是流程控制呢?流程控制指的是在编写代码时,有不同条件下需要执行的代码,满足该条件后将会执行这部分流程;这一部分流程可以是一条代码、空或多条代码。那我们的代码如何体现这个流程控制呢?其实在我们的程序运行中,会出现一些可能预计的情况,通过对这些情况的判定从而在某些情况出现时做响应;例如在做一台壁障小车时,判断前方是否有障碍物,若有则转弯或后退,其它情况则直走;在整个过程中,转弯和后退表示一个情况触发后需要响应的流程,其它情况则直走,这就是流程控制。从壁障小车的表现上看,则是有了逻辑;在魔法世界中,释放有逻辑的魔法就像一枚跟踪导弹,放出去必定命中敌人。

02

【深入浅出C#】章节 3: 控制流和循环:循环语句

循环语句是编程中常用的一种结构,用于重复执行特定的代码块。它的作用是在满足特定条件的情况下,反复执行一段代码,以实现重复性任务的自动化处理。循环语句在程序中具有重要的地位和作用。 循环语句的重要性体现在以下几个方面。首先,循环语句能够提高代码的复用性和效率,减少代码冗余。通过循环,我们可以将需要重复执行的代码块放入循环体中,避免了多次复制和粘贴相同的代码。其次,循环语句使程序可以处理大量数据或执行大规模的任务,从而提高程序的处理能力和效率。它可以让程序按需重复执行,处理大量数据集合或持续监控某些情况。此外,循环语句还可以实现特定的算法逻辑和控制流程,如排序、搜索、遍历等。 在编程中,循环语句是一种必备的工具,可以有效地解决各种重复性任务和问题。合理地运用循环语句能够简化代码的编写和维护,提高程序的可读性和可维护性。因此,对于开发人员来说,掌握循环语句的使用方法和技巧是至关重要的。它们可以帮助我们更高效地开发程序,处理大规模任务,并实现各种复杂的业务逻辑。

02

NeuroImage: 7-13岁儿童执行功能发育的脑网络研究

执行功能是指个体对各项认知能力进行协调监督,以保证个体以灵活而优化的方式实现某一特定目标的心理活动。执行功能作为一种高级认知能力,是个体成功完成日常生活中许多活动的重要条件。因此,越来越多的研究人员开始关注儿童青少年时期执行功能的发育特点。 近年来,许多研究表明执行功能的成功不仅依赖局部脑区的功能活动,还涉及到大尺度脑功能网络之间的协调合作。此外,越来越多的证据表明大尺度脑功能网络的发育变化有助于个体认知控制的提升。因此,揭示不同年龄的儿童在完成执行功能任务时大尺度脑功能网络的差异有助于进一步揭示儿童执行功能发育过程中的神经机制。 近期,浙江大学陈飞燕领衔的团队在NeuroImage发表题目《Modular segregation of task-dependent brain networks contributes to the development of executive function in children》的研究论文。他们运用了以图论为基础的脑网络分析方法,研究了儿童在完成执行功能任务时,在全脑功能网络模式上所表现出的发育特点,以及可能对执行功能行为绩效的提升存在的作用。 7-13岁是儿童各项执行功能及相关的脑功能快速发展的一个重要阶段,这一阶段的执行功能被认为是影响学校各方面学习和表现(如学业成绩、时间管理技能和其他与学校相关的行为)的一个关键因素。因此,该研究主要关注了7-13岁儿童基于任务的脑功能网络的发育变化特点。根据之前静息态脑功能网络或结构网络发育方面的研究结果,该研究假设,从7-13岁,基于任务的功能网络模块化结构会越来越清晰。随着年龄的增长,某些模块的模块内连接增加,模块间连接减少。此外,大脑功能网络的模块性分离可能会支持执行功能的提升。本文对该研究进行详细解读。

00

介绍功能测试中故障模型的建立

故障模型是将测试人员的经验和直觉尽量归纳和固化,使得可以重复使用。测试人员通过理解软件在做什么,来猜测可能出错的地方,并应用故障模型有目的地使它暴露缺陷。下面介绍功能测试中故障模型的建立。 1. 概述 故障模型是软件测试的基础,也是一个判断测试方法是否成熟的重要标志。在测试的过程中,要确保每一个目标状态都被测试,那么测试必须是系统的;为了最终定位软件缺陷,所以测试必须是集中的;测试需要使用大量的测试用例和重复性测试,因此测试必须是自动的。若要满足上述三个测试条件,我们必须建立故障模型。 故障模型是将测试人员的经验和直觉尽量归纳和固化,使得可以重复使用。测试人员通过理解软件在做什么,来猜测可能出错的地方,并应用故障模型有目的地使它暴露缺陷。它具有一定的形式和足够的信息对错误进行预测,因此对测试人员来说,构造一个准确的故障模型,是选择测试策略、设计测试用例和测试执行的基础。在建立故障模型时,希望故障模型在框架上是通用的,但是建立具体的故障模型时一定要针对具体的软件类型、应用环境、甚至开发工具才有意义。一个成熟的故障模型必须具备下列条件: 1)该模型是符合实际的:大多数系统中存在的故障都可以用该模型来表示; 2)模型下的故障个数是可容忍的:模型下的故障个数一般和系统的规模是成线性关系; 3)模型下的故障是可以测试的:存在一个算法,利用该算法可以检测模型中的每一个故障。 本文将从软件的功能和技术特点出发,如软件的输入、输出、数据以及处理等,分析在软件功能测试过程中,我们通常应建立的故障模型及按照故障模型所提供的缺陷类型寻找尽量多的缺陷。 2. 输入型故障模型 主要是对用户的各种输入进行建模,因为用户的输入是无法预期的,可能的组合状态也是千变万化。软件功能除了能让正确的输入得到正确的输出之外,还必须对非法和不合逻辑的输入进行处理,防止因数据异常造成不可挽回的错误。典型的建模方法有: 1)使用非法数据:从输入数据的类型、长度、边界值等方面考虑,测试软件是否允许不正确的输入进入系统并进行处理,是否有错误处理代码,代码是否正确。 2)使用默认值输入:检测软件中所使用的变量是否初始化,是否将非法数据默认为合法边界内的某个合理值。 3)使用特殊字:检测软件是否正确处理了特殊字符和数据类型。 4)使用使缓冲区溢出的合法输入:输入超过允许的最大长度的数据,检测软件是否检查字符串/缓冲区的边界。 5)使用可能产生错误的合法输入组合:测试多个输入值的组合,确认这些值的组合是否会互相影响而引起软件失效。 6)重复输入相同的合法输入序列:检测软件是否考虑了循环处理的边界。 3. 输出型故障模型 软件的输出通常是最直观也是用户最关注的,输出型故障模型就是从软件输出角度出发,分析造成故障的可能原因。例如通过一个正确的输入在不同情况下产生不同输出的情况可以对输入和输出的关系进行进一步验证;可采用列举等方法,强制软件产生不符合业务背景知识的无效的输出,从而进行处理,规避不必要的错误;强制修改输出的属性、查看输出结果,测试初始化代码和修改代码是否同步;检查用户界面刷新情况,在不同的操作下测试界面刷新时间是否正确、界面刷新区域计算是否正确。 在大多数的软件中,功能输出的正确与否直接决定了软件实现的好坏,输出型故障模型所覆盖的故障也占有相当大的比例。因此,我们在测试过程中应建立这种故障模型,从故障结果进行分析,判断造成故障的影响因素。 4. 计算型故障模型 对于部分软件程序,常需要进行大量的计算,因此该模型应该尽可能包括关于计算方面的各种错误。包括变量的定义与使用方面的错误;数据的冗余;数组变量的越界错误;数据类型不匹配的错误;还有数据操作方面错误,包括函数调用参数传递错误、赋值语句错误等。 在建立计算型故障模型的时候,要定义数据并且对这些数据执行各种故障操作,尽可能使模型比较完善。体现在功能层面上,可以使用非法的操作数和操作符组合来验证计算要求的合法性、强制使计算结果溢出考虑数据结构存储的正确性、同时对数据进行操作检测数据共享性等方法来建立故障模型。 5. 流程型故障模型 这是一种程序控制流的故障模型,是对在程序中同样占很大比例的循环结构和分支结构建立的模型。循环故障主要包括永不循环故障和死循环故障,这主要是由循环条件错误引起的。循环条件的错误中包括变量错误和运算符错误,在未执行循环之前,循环变量的初值设置出错以致永不循环;进入循环以后,循环变量的值不作修改以致发生死循环。 而分支故障则包括判定条件故障和谓词结构故障,由于判定条件的出错或者变量初值设置错误而导致不执行分支结构;对于进入了分支结构的执行,可能因为谓词的错误而提前退出分支结构。 由此可知,流程型故障模型很可能是由一串连续的故障所组成的。因此在软件功能测试中,我们可以通过判断软件流程是否正确执行、功能分支是否覆盖全面、循环操作是否正常结束等方法来检测软件流程的正确性。 6. 资源型故障模型 资源型故障模

01
领券