APP开发的详细流程
随着互联网的发展越来越多的企业要开发独立的APP进行业务拓展,那么APP开发的流程是怎么样的呢?APP一个APP大概需要多少钱呢?需要注意什么呢,今天我们来探讨一下。
APP开发总体是看功能要求来评估工作量,此外大型的APP,用户量涉及架构设计的价格更高。一般来说APP开发要做安卓、IOS两个系统版本的,现在部分要做windows、鸿蒙的暂且不考虑;APP做双系统的起步价一般10万以上,开发费用,具体上应用市场单独计费;价格太低的基本不靠谱,还不如做微信小程序或者H5;一般个人创业者不建议做app,成本高,风险较大,后期推广运营成本高。
那么APP开发的详细流程有哪些呢?
1、明确APP开发的目的与商业模式
了解客户公司或制作软件的商业目标,通过研究调查用户需求确定对方树立品牌的方向,通过分析竞争产品最终做出相关报告,连同收集的历史数据一同分析做出总结数据报告。选区部分用户对软件进行体验,收集用户习惯报告和用户体验报告,最终制作出BRD需求文档。
2、APP开发 需求明确
在APP项目正式启动前,需要产品经理和项目监理、客户作充分沟通,对APP开发的功能需求进行评估、确认项目的开发费用和时间。这时的项目只有一些抽象的想法,还需要全体开发人员一起进行多轮需求讨论会,主要讨论需求的合理性及存在的必要性,研究并对可行性进行评估,开发人员还可以提出自己的建议,结合客户及开发的建议决定需求是否可以开发,并将最后的需求一步步拆分、细分,最后分解成一个个明确的需求功能清单,即APP开发技术解决prd文档。
梳理清楚用户的需求非常关键。要结合大量的市场分析及经验,明确app可以满足用户的哪些真实需求,最好通过用户的语言进行产品使用场景描述。之后根据用户的需求,形成系统性的功能模块,根据用户使用流程、业务流程等逐步完善。
3、APP UI设计
对手机app的各个功能模块进行划分,明确核心基本功能,制作设计app原型图、业务流程图等。产品经理根据已明确的APP开发技术需求文档,对APP进行功能的规划,页面及布局进行设计,并设计各个页面的跳转逻辑,最终输出APP各个页面的原型设计图。
将完成了的原型设计图交给客户和领导审批通过后,再交给全体开发人员,共同讨论功能需求的合理性及存在的必要性,最后,产品经理就能得到跟客户确定的完整产品需求文档(PRD)。
UI设计师设计app页面的最终效果图,并切图成为可以填充的app素材。根据产品的原型页面设计出美观大方的UI界面,做好配色、元素设计等,最后产出每张APP页面的高保真设计效果图,使UI效果图基本上与最终的APP页面效果一致。
4、APP功能开发
前端开发工程师在收到UI效果图后,使用前端代码将设计图还原展示出来,包括各种特效、色值、按钮、页面切换、布局的合理性等,这些细节将直接影响到用户体验。
前端开发整体完成后,继续进行的是APP后台管理系统服务端开发。APP后台管理系统开发包括架构设计、数据库设计、业务功能实现及接口开发、管理后台的开发等。APP后台管理系统开发就像房子的地基,它是APP的底层框架,直接影响到APP的稳定性和可塑性,占有重要的地位。
手机软件开发app的开发阶段,需要最少5名以上的技术人员进行开发,包含安卓工程师、IOS工程师、JAVA/php工程师,测试工程师等不同的岗位开发人员。
5、APP系统内测
app开发之后可以在内部开发团队进行内部测试,内部测试完成后可以在前期种子用户间进行多人详细的试运营测试,发现问题不断修改、完善,试运营测试完成后,系统开发基本完成,把最终版提交到应用市场上线。提交应用市场由于国内安卓应用市场比较分散,包含各个不同的手机应用市场,还包含类似腾讯应用宝等不同应用市场,周期也比较长,一般半个月到一个月周期不等
6、APP上线运营维护
APP开发完成后,软件系统由管理后台系统进行维护。根据用户市场的反馈意见,以及业务发展需要对APP进行维护和迭代升级。
PHP 8:函数和方法
作者 | Deepak Vohra
译者 | 刘雅梦
策划 | 丁晓昀
本文属于专题文章《深入浅出 PHP 8》。 根据w3tech的数据,PHP 仍然是 Web 上使用最广泛的脚本语言之一,77.3%的网站使用 PHP 进行服务器端编程。PHP 8 带来了许多新特性和其他改进,我们将在本系列文章中进行探讨。PHP 8.0 添加了对多个函数和方法相关特性的支持,其中一些是对现有特性的改进,而另一些则是全新的特性。PHP 8.1 中增强的可调用语法可用于通过可调用对象创建匿名函数。命名函数参数可以与位置参数一起使用,另外还有一个好处,即命名参数没有顺序,可以通过它们的名称来传达含义。纤程(Fiber)是可中断的函数,增加了对多任务的支持。
对象继承是大多数面向对象语言(包括 PHP)所使用的编程范式。它可以从任何扩展类中重写公共和受保护的方法,以及在类中定义的类属性和常量。在 PHP 中,公共方法不能通过更严格的访问来重新实现,例如将 public 方法设为 private 。为了演示这一点,考虑一个扩展了类 A 的类 B,它重新实现了类 A 中一个公共方法。
运行时,脚本会生成如下的一条错误信息:
相反,在类中定义的私有方法不是继承的,可以在扩展它的类中重新实现。例如,类 B 在下面的脚本中扩展了类 A,并重新实现了类 A 中一个私有方法。
在 PHP 8.0 之前,对扩展类中私有方法的重新声明应用了两个限制:不允许更改 final 和 static 修饰符。如果 private 方法被声明为 final ,则不允许扩展类重新声明该方法。如果私有方法被声明为静态的,那么它将在扩展类中保持静态。而且,如果私有方法没有static 修饰符,则不允许扩展类添加static 修饰符。在 PHP 8 中,这两个限制都被取消了。以下脚本在 PHP 8 中能正常运行。
PHP 8 中唯一的私有方法限制是强制使用 private final 构造函数,当使用静态工厂方法作为替代时,有时会使用private final来禁用构造函数。
该脚本生成如下的错误信息:
在 PHP 8 中,单个可变参数可以替换任意数量的函数参数。考虑下面的脚本,其中类 B 扩展了类 A,并用一个可变参数替换函数 sortArray 的三个参数。
可以使用多个参数调用类 B 中的 sortArray 函数。
输出结果如下所示:
可调用(callable)是可以被调用的 PHP 表达式,例如实例方法、静态方法或可调用对象。例如,可调用可用于为方法调用创建简短的表达式。在 PHP 8.1 中,可以用新的可调用语法:
AVariableCallableExpression(…)
AVariableCallableExpression 表示一个变量可调用表达式。省略号…包含在语法中。
这有两个问题:
- 语法涉及字符串和数组
- 在创建可调用时,作用域不会被维护。为了演示这一点,请考虑如下用于对数组进行排序的脚本,其中 getSortArrayMethod() 方法返回 sortArray() 方法的可调用项,[$this,\’sortArray\’] 。
该脚本会生成如下的错误信息:
使用 Closure::fromCallable([$this, \’sortArray\’]) 而不是 [$this, \’sortArray\’] 可以解决作用域问题,但使用 Closure::fromCallable 方法会使调用变得冗长。新的可调用语法解决了作用域和语法冗长的问题。使用新的可调用语法,函数变为:
数组根据输出进行排序:
新语法可以与涉及字符串和数组的传统语法结合使用,以解决作用域问题。创建可调用的作用域将保持不变。
新的可调用语法也可以与静态方法一起使用,如下面的脚本所示,该脚本包含一个静态函数。
输出结果与之前的相同:
以下是调用方法的等效方法:
以下是调用静态方法的等效方法:
即使函数声明了形参,也可以使用新的可调用语法。
如果一个方法声明了任意参数,则必须使用它的参数来调用可调用对象。
简化的可调用语法可以用于任意的 PHP 可调用表达式。用于对象创建的 new 运算符不支持可调用语法,因为可调用语法 AVariableCallableExpression(…) 没有指定构造函数参数的规定,这可能是必需的。以下是不支持的示例:
生成的错误信息为:
以下的脚本演示了受支持的所有可调用表达式。
PHP 8.0 的另一个新特性是支持在函数的参数列表末尾添加一个尾逗号,以提高可读性。任何尾逗号都将被忽略。尾逗号可能并不总是有用的,但如果参数列表很长,或者参数名称很长,则可能会有用,因此可以垂直列出它们。闭包使用列表也支持尾逗号。
PHP 8.0 不支持在必选参数之前声明可选参数。在必选参数之前声明的可选参数都是隐式的必选参数。
下面的脚本演示了必选参数的隐式顺序,以及尾逗号的使用。
输出如下所示:
可空参数不会被视为可选参数,可以使用 $param=null 形式或显式可空类型在必选参数之前声明,脚本如下所示:
PHP 8.0 除了已经支持的位置形参和实参之外,还增加了对命名函数形参和实参的支持。命名参数在函数调用中的传递语法如下所示:
命名参数的一些好处如下所示:
- 可以为函数参数指定一个有意义的名称,使它们能够自我记录
- 按名称传递时,参数与顺序无关
- 可以任意跳过默认值。在下面的脚本中, array_hashtable 函数声明了命名参数。 该函数传递的实参值可以带参数名,也可以不带参数名。当传递位置实参时,使用函数形参声明顺序。但传递命名实参时,可以使用任意顺序。
输出结果为:
命名实参和位置实参可以在同一函数调用中使用。对相同的示例函数 array_hashtable 一起使用混合参数调用。
输出结果为:
请注意,命名参数只能用于位置参数之后。下面的脚本颠倒了顺序,在命名参数之后使用位置参数:
该脚本生成的错误信息为:
即使使用命名参数,也不推荐在必选参数之前声明可选参数,脚本如下所示:
输出将包括已弃用(不推荐)信息:
当在必选命名形参之后使用可选命名形参时,命名实参可用于跳过函数调用中的一个或多个可选形参,脚本如下所示:
输出结果为:
你可以只使用可选参数的子集来调用函数,而不用考虑它们的顺序。
输出结果如下所示:
即使使用可选参数的子集调用函数,也不能在命名参数之后使用位置参数,脚本如下所示:
生成的错误信息以下所示:
PHP 8.1 改进了命名实参特性,在解包实参后支持命名实参,脚本如下所示:
输出如下所示:
但是,命名的参数不能盖前面的参数,脚本如下所示:
输出如下所示:
在 PHP 8.0 之前,如果在静态上下文中调用非静态方法,或者静态调用,则只会收到一条已弃用(不推荐)的信息。使用 8.0,你现在会收到一条错误信息。此外, $this 在静态上下文中是未定义的。为了演示这一点,请考虑如下的脚本,其中使用静态语法 A::aNonStaticMethod() 调用了非静态方法 aNonStaticMethod() 。
如果你运行这个脚本,将会得到如下的错误信息:
PHP 8.1 添加了对纤程(Fiber)多任务的支持。纤程是一个可中断的函数,它具有自己的堆栈。纤程可以从调用堆栈中的任何位置挂起,然后再恢复。新的 Fiber 类是一个 final 类,它支持以下的公共方法:
纤程只能启动一次,但可以挂起并恢复多次。下面的脚本通过使用纤程在数组上执行不同类型的排序来演示多任务处理。纤程在每次排序后都会挂起,然后再恢复执行不同类型的排序。
输出如下所示:
如果纤程在第一次挂起后没有再恢复,则只进行一种类型的排序,这可以通过注释掉对 resume() 的两次调用来实现。
输出的是第一次排序的结果:
PHP 8.0 引入了一个名为 Stringable 的新接口,它只提供一个方法 __toString() 。 __toString() 方法如果在类中提供,将隐式实现 Stringable 接口。考虑提供 __toString() 方法的类 A。
该脚本从 Stringable 的类型检查中返回 1。
然而,反之则不然。如果类实现了 Stringable 接口,则必须显式提供 __toString() 方法,因为该方法不会自动添加,比如:
PHP 8 引入了许多属于其标准库的新函数。
str_contains 函数返回一个 bool 值,用于指示作为第一个参数的字符串是否包含作为第二个参数的字符串。以下脚本将返回 false :
下面的脚本返回 1,或 true:
str_starts_with 函数返回一个bool 值 ,指示作为第一个参数的字符串是否以作为第二个参数的字符串开头。以下脚本将返回 false 。
下面的脚本将返回 1,或 true。
str_ends_with 函数返回一个bool 值 ,指示作为第一个参数的字符串是否以作为第二个参数的字符串结尾。以下脚本将返回 false 。
下面的脚本将返回 1,或 true。
fdiv 函数将两个数字相除并返回一个 float 值,脚本如下所示:
输出为:
fdatasync 函数在 Windows 上的别名为 fsync ,用于将数据同步到文件上的流中。为了演示它的用法,在包含要运行的 PHP 脚本的脚本目录中创建一个空文件 test.txt 。运行脚本:
随后,打开 test.txt 文件会发现包含如下的文本:
array_is_list 函数返回布尔值,用于指示给定的数组是否为列表。数组必须从 0 开始,键必须是连续的整数,并且顺序正确。下面的脚本演示了 array_is_list 函数:
输出为:
魔术方法是 PHP 中用于覆盖默认操作的特殊方法。它们包括如下的方法,其中构造函数 __construct() 可能是大家最熟悉的:
从 PHP 8.0 开始,魔术方法定义的签名必须要是正确的,这意味着如果在方法参数或返回类型中使用类型声明,则它们必须与文档中的声明相同。新的 __toString() 方法的返回类型必须要声明为 string 。下面的演示将返回类型声明为 int :
将生成如下的错误信息:
但是,未通过定义声明返回类型的函数(如构造函数)不能声明返回类型,即使是 void 返回类型也不行。示例如下脚本所示:
该脚本将返回如下的错误信息:
所有魔术方法,除了少数例外(例如 __construct() )外,都必须声明为具有公共可见性。为了演示这一点,声明了一个带有 private 可见性的 __callStatic 。
输出的警告信息为:
尽管可以省略混合返回类型,但方法签名也必须相同。例如,在下面的脚本中,类 A 声明了 __callStatic 而没有指定其返回类型,而类 B 将其第一个参数定义为int :
输出的错误信息如下所示:
在 PHP 8.1 中,大多数内部方法,即内部类中的方法,都已经“试探性地”开始声明返回类型。试探性地暗示,虽然在 8.1 中只会引发不推荐(Deprecation)通知,但在 9.0 版中,则会输出错误条件信息。因此,任何扩展类都必须声明与内部类相兼容的返回类型,否则将会引发已弃用(不推荐)通知。为了演示这一点,扩展内部类 Directory 并重新声明没有返回类型的函数 read() :
该脚本将生成已弃用(不推荐)通知:
但是,以下脚本是可以的:
添加 #[\\ReturnTypeWillChange] 属性能抑制已弃用(不推荐)通知:
虽然包含有关方法参数的详细信息的异常堆栈跟踪对调试非常有用,但你可能不希望输出某些敏感参数的参数值,例如与密码和凭据关联的参数值。PHP 8.2 引入了一个名为 \\SensitiveParameter 的新属性,这样,如果使用 \\SensitivyParameter 属性注解方法的参数,则该参数的值不会在异常堆栈跟踪中输出。
为了演示这一点,考虑下面的脚本,其中函数 f1 具有与 \\SensitiveParameter 属性关联的参数 $password 。
为了演示 \\SensitiveParameter 特性,该函数只是抛出一个异常。调用函数:
请注意,异常堆栈跟踪不包含 $password 参数的值,而是列出了 Object(SensitiveParameterValue) 。
内置函数 utf8_encode() 和 utf8_decode() 经常被误解,因为它们的名称意味着对任何字符串进行编码/解码。实际上,这些函数仅用于编码/解码 ISO8859-1,即“Latin-1”字符串。此外,它们生成的错误信息对于调试来说描述性不够。PHP 8.2 已经弃用了这些函数。下面的脚本使用了它们:
对于 PHP 8.2,会输出已弃用(不推荐)通知:
在 PHP 8.2 中,函数 iterator_count 和 iterator_to_array 接受所有可迭代的对象。 iterator_to_array() 函数将迭代器的元素复制到数组中。 iterator_count() 函数对数组的元素进行计数。这些函数接受一个 $iterator 作为第一个参数。在 PHP 8.2 中,$iterator 参数的类型已从 Traversable 扩展为 Traversable|array ,以便接受任意的可迭代值。
下面的脚本演示了它们在 arrays 和 Traversables 中的使用。
输出如下所示:
在这篇 PHP 8 系列文章中,我们讨论了与函数和方法相关的新特性,其中最突出的是命名函数的形参/实参、简化的可调用语法和被称为纤程(Fiber)的可中断函数。
在本系列的下一篇文章中,我们将介绍 PHP 类型系统的新特性。
原文链接:
https://www.infoq.com/articles/php8-functions-methods/
相关阅读:
PHP 8:注解、match 表达式及其他改进
PHP 8:类和枚
软件开发流程
先上一个软件开发的整体流程图,这就是大名鼎鼎的“瀑布模型(WaterfallModel)”。据说由温斯顿·罗伊斯(WinstonRoyce)在年提出。
瀑布模型的特点为:上一阶段的结果为本阶段的输入,开发进程从一个阶段“流动”到下一个阶段。
(图中右侧括号中为每个阶段的输出物。)
一般软件售前人员对这个流程比较熟悉,这其中项目规划、可行性论证报告、需求说明书等,通常都由IT售前人员提供。
如果将瀑布模型的设计部分分为总体设计、详细设计两部分,即“软件开发的8个流程”:
1、问题定义阶段
用户提出一个软件开发需求以后,分析人员首先要明确软件的实现目标、规模及类型:如它是数据处理问题还是实时控制问题,是科学计算问题还是人工智能问题等。
2、可行性研究
基本任务:“对于上一个阶段所确定的问题有行得通的解决办法吗”?
内容包括经济可行性、技术可行性、法律可行性、不同方案。
结束标准:提出关于问题性质、工程目标和规模的问题定义书面报告;提出可行性研究报告。
3.需求分析
基本任务:“为了解决这个问题,目标系统必须做什么?”
确定系统必须具有的功能和性能,系统要求的运行环境,并且预测系统发展的前景。
结束标准:软件需求规格说明书(specification)
4.总体设计(概要设计)
基本任务:“概括地说,应如何解决这个问题?”
设计出实现目标系统的几种可能的方案。推荐一个最佳方案。
结束标准:概要设计文档
5.详细设计
基本任务:“应该怎样具体地实现这个系统呢?”
结束标准:设计出程序的详细规格说明。
6.编码
基本任务:写出正确的容易理解、容易维护的程序模块
结束标准:以某种程序设计语言表示的源程序清单
7.测试(单元测试和综合测试)
基本任务:在设计测试用例的基础上检验软件的各个组成部分是否达到预定的要求。
结束标准:软件合格,能交付用户使用。
8.软件维护
基本任务:使系统持久地满足用户的需要。
改正性维护,适应性维护,完善性维护,预防性维护。
虽然后来提出很多模型,如演化模型(evolutionarymodel)、增量模型(incrementalmodel)、原型模型(prototypingmodel)等,但现在软件开发的流程,依然总体遵循瀑布模型。
如何搭建一个系统
说完流程,再说说系统是如何被开发人员搭建出来的。
系统的百科定义为:软件系统(SoftwareSystems)是指由系统软件、支撑软件和应用软件组成的计算机软件系统,它是计算机系统中由软件组成的部分。
搭建系统可以分为三个步骤:环境部署、软件开发、软件部署。
1、环境部署
准备服务器,部署操作系统、软件环境、安全软件、FTP服务器等。数据库和应用可分开布置在多个服务器,也可布置在同一服务器。
准备网络,分为内网和外网。外网需要购买公网IP和域名。
负责人:网络管理员
2、软件开发
包括开发语言选择、架构设计、数据库设计等工作,并进行编码、编译、测试、打包。
负责人:程序员
3、软件部署
将程序文件上传到服务器,进行部署、配置,成功后即可通过客户端访问项目。
负责人:软件实施
软件开发阶段
下面以java语言开发为例,简单讲讲程序员是如何进行软件开发的。
(本部分参考了“软帝在线”公众号、博客园“架构与我”的文章)。
1、新建java文件(或工程)
java源代码本质上就是普通的文本文件,可以用txt等工具编辑java代码(程序员一般采用源代码编辑工具,如:Notepad++;或集成开发工具IDE,如:Eclipse)。txt编写后需将文件扩展名改成java。
2、编写代码
以“HelloWorld”举例编写代码:
publicclassHelloWorld{
publicstaticvoidmain(String[]args){
\”HelloWorld\”);该程序表示的意思是输出HelloWorld这样一段话。
3、编译程序
Java程序之所以能做到跨平台运行,是因为Java程序运行在JVM中的,然而JVM只能够识别字节码文件,而不能直接识别Java文件。所以需要先将Java文件编译成字节码文件,即class文件,然后字节码文件才能够在JVM中运行。
编译文件,可以通过手动执行Dos命令javac,或直接用编译器如Eclipse完成。
4、运行程序
可在Dos命令窗口中输入java命令,按回车,输出HelloWorld;
或在编译器的控制台中看到输出结果。
5、单元测试
单元测试(模块测试)是开发者对编写的一小段代码,检验一个很小的、很明确的功能是否正确。
通常采用JUnit框架(多数java开发环境已集成)进行测试,即所谓白盒测试,叫“白盒”是因为程序员知道被测试的软件如何(How)完成功能和完成什么样(What)的功能。
测试通过后,就完成了软件开发阶段,可以打包部署了。
详细有:
1.c++开发投屏
2.c++开发手机自动下载软件
3.c++开发提取手机文件
4.c++开发电脑手机文件互传
5.c++开发查看手机app
6.c++操作手机小程序
7.织梦仿站
8.vue页面
9.php接口开发
欢迎交流
本文作者及来源:Renderbus瑞云渲染农场https://www.renderbus.com
文章为作者独立观点不代本网立场,未经允许不得转载。