`

开发一个iOS应用没有那么容易

 
阅读更多

http://www.williamlong.info/archives/3061.html

 导读:这是来自新加坡的 iOS 开发者 Kent Nguyen 发表在1月底的一篇博文。这篇吐槽文在 iOS 开发圈子里流传甚广,从原文150多个评论就可见一斑,现翻译如下。

  让我们开门见山吧:做一个iPhone应用需要花多少钱?

  就是这个最常见的问题,我的很多朋友(大多是些西装革履的商务人士),还有我那些个对技术一知半解的客户们,他们都问过我这个的问题。通常,我会先给出一个大致的报价,这个报价并没有细致到需要签合同确认每一个功能点的地步。即便是这样,每当的我报价一出口,对方都毫无例外的给惊着了(当然不是因为便宜)。

  说实话,我没有狮子大开口。看看StackOverflow上这个著名的帖子吧,讨论的是开发Twitterific这样一款应用需要多少钱,后来讨论范围扩展到开发一个iOS应用的合理费用范围。虽然这个帖子是在2008年发布的,而帖子的最佳答案是由一名来自Twitteriffic的开发人员于2010年回答的,但是时至今日,帖子里面讨论的数字仍然是很靠谱的,而且我预计到2012年底依然有效。而我的报价和这个帖子里面的数字比起来,简直是小巫见大巫了。

  现在的趋势是,什么公司什么业务都想搞个iOS客户端,并且这种趋势在2012年看似依然火爆。所以我想起来写这篇博文,我想说一下开发一个iOS应用会碰到的各种细节问题和横生的变数,借此解释为什么iOS应用开发成本这么贵。如果你在考虑搞一个iOS应用,而你本身是搞业务而不是做技术的,如果你目前正在招标或者仅仅是想了解一下,那我这篇博会对你有帮助。当然,我说的东西并不局限于iOS应用开发,对Android、Windows Phone或者是Blackberry(如果RIM还能活的话)等移动应用平台基本上也是适用的。

开发一个iOS应用没有那么容易

  开发之前需要仔细考虑的

  别做拍脑瓜的决策,在开工之前你需要考虑的比你想象的要多。我通常会帮助或者指导客户把以下几个要素都过一遍:

  一:和客户谈他们的移动应用,最让我吃惊的是他们从来没有想过支撑一个iPhone应用运行,背后需要涉及到的方方面面。他们想象中的iPhone是独立存在于这个宇宙的,是如此的简单,以至于他们要我很快就给出一个项目预算报价,而不用讨论诸多细节。我问他们:“你们是否考虑过后台服务器的事情?你们的应用需要和后端服务器做数据通讯?” 什么,听不懂?好吧,我用地球人的语言再把这个问题讲 一遍:“你们的应用不是需要用户注册嘛,你们考虑过把用户的数据存放在哪里了吗?我们需要一个地方去保存这些以后会用到的数据。” 第一次碰到这样的客户时,哥简直就怒了。后来我发现这不是客户的错:我是搞编程的,CS架构对我来说就像吃饭睡觉一样是不假思索的东西,而我的客户尽是些高富帅,他们懂个毛CS架构!

  所以,如果你不大懂技术,那请仔细听我说:如果你想做的移动应用需要用户注册和登录,或者你想随时控制移动应用的一些输出,甚至是你仅仅是需要一个用户反馈意见调查表这么简单的功能,那么,你得搞一台后端服务器。

  二:好了,现在你知道你需要一台后端服务器。同时你还需要想办法让你的iOS应用和你的服务器能够对话,就是相互间接收数据什么的。不,这个问题不是简答靠什么标准的即插即用的东东就能解决的,不是你们想象的那样!所有的东西都需要定制化开发,这就好比发明一门语言:你希望你的服务器和你的应用之间能够通过一种语言沟通,但是你不希望其他人听得懂这门语言。

  用行话说这就是制定服务器端API接口,或简称API。这些API应该在开发iPhone客户端之前就到位了。为什么?因为你必须先规定好一门语言的单词和语法,然后才能用这门语言说话吧!?好了,这就带出了第三点—如何开发这些API。

  三:API的成功定制是项目成功的一半(反之亦然),所以千万不要掉以轻心。你要考虑你的业务数据模型、业务流程、调用业务需要提供的参数、特定事件发生时数据间该如何互动等等。简单来说,我们要做的就是开发一个网站,上门跑着你的业务流程,只不过这个网站的所有运行结果都不是通过网页形式展现出来,而是呈现在一行行的文本和数字中。举个例子:一个登录成功的反馈页面仅仅包含YES一个单词。

  iPhone应用需要访问这些预先定义好的接口,并且按预定义格式提供必要的输入(比如用户名和密码),然后要对服务器端的反馈(YES或者NO)做出解析处理。所以,没有什么移动应用能够自动的含有用户注册和登录功能。

  服务器端开发需要考虑的问题太多了:选择服务器,选择用什么语言开发,主机放在哪里才能增加访问速度,等等,这里我就不展开了。如果这一切对你来说很陌生,那么你最好去问问团队里的技术负责人,或者干脆让开发人员做决策。

  四: 所以,关于服务器端API,你或者让自己的技术团队把它开发好,再将完善的API文档交给iPhone应用开发人员;或者你支付iPhone应用开发人员额外的报酬来搞定这些。你找的iPhone应用开发人员可能会服务器端开发也可能不会。如果他会的话,我建议最好让他也同时负责服务器端开发,因为他最清楚iPhone应用中需要哪些服务器端API。

  如果你的服务器端API已经存在了,那么除了向iPhone应用开发人员提供相关文档之外,你还要考虑让他能够便捷的同服务器开发团队沟通,因为大多数情况下,iPhone应用需要在已有API基础上增加一些新的接口。

  现在我们来看看iPhone应用开发本身

  扯了大半天,我们终于开始谈iPhone应用开发本身了。一般来说,iOS平台上做所有事情都不能随心所欲。你最好在开发人员写代码之前把所有的需求都确认好好。这和开发网站不一样,按照实现签订的合同开发iOS应用,开发过程中对需求变更的容纳度可能很低:

  用户界面:无论你打算采用iOS标准界面还是自定义元素,在开发开始前一定要确认清楚,因为应用的程序架构是根据界面和用户使用流程来设计的。一个很好的例子就是在界面底部使用了iOS标准的标签栏(Tab Bar),此后如果你想让标签栏里面的图标变成彩色的,这个代码改动量可没你想象的那么小!

  代码之间的耦合:如果是开发网站,你可以随意的添加一个页面或者一处链接。做iOS应用就没有那么简单了,很多东西一开始都要设计好,后期的一处改动会牵连很多东西,具体原因是你无法理解的。iOS应用的代码写好之后,再改动行不行?行!但必须小心。 这就像设计电路板一样, 如果你不小心把那根线搭错了,整块电路板就会不工作。有人说架构优良的程序可以有很高的延展性,那纯属纸上谈兵。在About屏幕上添加一个电子邮件按钮可能只需要几行代码的工作量,而添加一个转发到新浪微薄的按钮(译者注:原文是添加一个Facebook Like)就完全不是那么简单的事儿了! 

  让一个iPhone应用同时也支持iPad:如果要评选最坑爹“需求变更”,那么这个绝对是当之无愧的。理由很简单:支持iPad根本不是TMD什么附加功能!iPad应用基本上都比iPhone应用来得要复杂,界面设计和用户体验也大不一样。我问你,制造一辆电动自行车,然后把它改装成一部烧汽油的摩托车,这能是一回事儿吗!?电动自行车跟摩托车看起来是很像,但是制造它们完全是两码事。

  拿广受欢迎的Facebook官方应用来说,它的iPhone和iPad版本看似相似,实际用户操作流程完全不同。不仅仅是界面上的不同会带来额外的工作,对后台服务器API的需求也可能不一样。拿我熟悉的一个应用Denso来说(我熟悉它因为这是我开发的),它的iPad版本比iPhone多了几个功能,这些都需要额外的服务器端API来支持。记住,iPhone和iPad应用的用户体验需求是完全不一样的。 

  准备好开始了吗?

  希望此文能够帮助你和你的团队了解移动应用开发幕后的方方面面。除非你们要做一个像计算器那么简单的单机应用,否则你们很难用极低的成本搞定。综上所述,如果你觉得外包成本太高,那你只好招人自己开发。

  当然,如果你决定了要外包移动应用开发,那么我还要提醒一点:公司政治。如果你是在一家大公司或者有着严格制度的机构里面干活,那么帮助合同开发者搞定那些个规章制度上的繁文缛节,对你来说是非常重要的一项工作,必要的时候甚至可以做一些政策上的变通。 我同几个大型企业客户接触过,当我要求看他们的服务器端数据接口的时候,他们流露出很不安的表情。我想这或许是因为他们受制于公司规定而不能透露信息,这无可厚非;或者他们还没有想好这种情况下该如何操作;或者他们的品牌制度蛋疼到需要在移动应用的每个屏幕上都摆着公司logo!最终我没有和这样的企业客户合作,因为我无法想象如果有一天我需要增加一些服务器端API接口的话,和他们的规章和流程折腾,那将会是多么悲剧的事情。

  PS:开发移动应用很耗费时间,你最好有耐心。 

分享到:
评论

相关推荐

    iOS 10应用开发基础教程

    它是Apple官方的开发工具,包含了编写、测试和调试iOS应用所需的所有组件。Xcode的Interface Builder允许你通过拖放方式创建用户界面,而Swift Playgrounds则提供了一个实时查看代码效果的环境,这对于学习和试验新...

    企业级IOS应用开发

    ### 企业级iOS应用开发知识点概述 #### 一、企业级iOS应用...综上所述,《企业级iOS应用开发》一书深入浅出地讲解了iOS应用开发过程中所涉及的各项关键技术点,对于希望涉足该领域的开发人员来说具有很高的参考价值。

    ios9应用开发入门经典第七版

    本书是为从未进行i O S 开发,但使用过M a c i n t o s h 平台的读者编写的,读者不需要有 Swift、Cocoa和Apple开发工具方面的经验。...有关iOS开发的信息浩如烟海,但 本书的篇幅有限,只能为您打下坚实的iOS开发基础

    swift-CreditCardForm-iOS是一个iOS演示应用程序允许开发人员创建实际效果的信用卡用户界面

    在Swift编程语言中,开发iOS应用时,设计用户界面(UI)是至关重要的一步,尤其在处理金融类应用时,如信用卡输入界面。"swift-CreditCardForm-iOS"项目提供了一个现成的示例,它帮助开发者创建具有真实感的信用卡...

    一款iOS BLE蓝牙调试工具,非常简单容易,也可以作为一个蓝牙库.zip

    标题中的“一款iOS BLE蓝牙调试工具,非常简单容易,也可以作为一个蓝牙库”表明这是一个针对iOS平台的蓝牙低功耗(BLE, Bluetooth Low Energy)开发工具,它的特点是简单易用,并且能够作为蓝牙库进行集成。...

    IOS9开发指南

    总的来说,iOS 9开发指南旨在提供一个全面的教程,帮助开发者充分利用新系统特性,无论是Objective-C的老手还是Swift的新手,都能在实践中迅速提升技能,创造出优秀的iOS应用程序。通过学习和实践,开发者不仅可以...

    25个增强iOS应用程序性能的提示和技巧

    在iOS应用开发中,尤其是在处理UITableView和UICollectionView时,正确使用`reuseIdentifier`对于提升性能至关重要。 ##### 实现方式: - 当tableView请求新的cell时,通过`dequeueReusableCellWithIdentifier:`...

    ios应用源码之位于顶部的黑酷tab view视图demo 2018127

    在iOS应用开发中,创建一个美观且功能丰富的Tab View界面是一项常见的任务。"ios应用源码之位于顶部的黑酷tab view视图demo 2018127" 提供了一个实例,展示了如何实现这样的设计。这个源码示例可能是针对iOS开发者,...

    iOS开发规范文档

    遵循这些规范,开发者可以创建出高质量的iOS应用程序,同时降低维护成本,提高开发效率。这些规范不仅适用于Objective-C,也适用于Swift开发,因为Swift虽然有自己的语法特性,但许多命名和组织原则是通用的。

    一个简易的iOS开发框架,简化iOS开发工作量.zip

    "一个简易的iOS开发框架,简化iOS开发工作量.zip" 提供了一个专为iOS应用设计的轻量级框架,旨在帮助开发者更高效地完成项目。下面我们将深入探讨这个框架可能包含的关键知识点,以及它如何改善iOS开发体验。 1. **...

    IOS 8 开发指南 源码2

    通过这些新功能和改进,开发者得以创建更加丰富、个性化和实用的iOS应用,进一步提升了用户体验。在源码2中,可能包含了这些特性的实现示例,供学习和参考。对于开发者来说,深入理解并掌握这些知识点,能够帮助他们...

    ios开发 Xcode ios12.0 (16A5327d)支持包

    在使用Xcode开发iOS12.0应用时,开发者需要注意以下关键点: 1. **适配新特性**:iOS12引入了许多新特性和改进,比如屏幕时间(Screen Time)、勿扰模式(Do Not Disturb)、强密码建议(Strong Password ...

    IOS应用源码之【框架】ShareKit - 分享到开心,豆瓣,腾讯,新浪微博.rar

    开发iOS应用通常使用Swift或Objective-C语言,并通过Xcode集成开发环境进行。 在【压缩包子文件的文件名称列表】中,虽然没有具体的文件名,但我们可以推测其中可能包含的内容: 1. ShareKit源代码:这包括了...

    ios应用源码之横条显示滚动的股票动态 2018128

    在iOS开发中,创建一个应用来显示横条滚动的股票动态是一项常见的需求。这个源码项目专注于实现这样一个功能,让用户能够实时查看股票价格的变化。本文将深入探讨这个项目的相关知识点,包括iOS应用开发的基本原理、...

    flash ios 开发证书

    flash ios发布 ipa 证书 大家都知道,Flash CS5 可以...所以,这里是一种方法,可以免99刀的Apple developer费用,并且可以在PC环境下开发iOS应用。 关键是这个“p12.zip”里的“.mobileprovision”文件不容易弄到。

    ios开发Tea加密解密

    本教程将深入讲解如何在iOS应用中实现Tea加密解密,以及如何正确地存储和恢复加密数据。 Tea加密算法基于两个32位的整数,它使用了四轮非线性变换,通过多次加法、乘法和位移操作来实现数据的加密。Tea算法的特点是...

    10个必需的iOS开发工具和资源

    (在这里,我再闲扯一句,虽然Android的开发好像整整 XML文件界面就出来了,其明显比iOS的开发要容易很多,但是我还是觉得iOS的生命力要强过Android,看看Android今天的应用就知道,有时候入门门槛低不是一些好事,...

    IOS应用源码——Three20 TTLauncher for iOS.rar

    "IOS应用源码——Three20 TTLauncher for iOS.rar" 这个标题揭示了我们讨论的核心内容,即一个针对iOS平台的应用程序源代码,它使用了Three20库,并且包含了TTLauncher组件。Three20是一个开源的iOS开发框架,它为...

    IOS应用源码之颜色拾取器 .rar

    这份"IOS应用源码之颜色拾取器 .rar"包含了一个实现这一功能的源代码,对于iOS开发者来说,这是一个学习和理解颜色选择器实现的好资源。 首先,我们要了解iOS中的颜色表示。在iOS中,颜色主要通过`UIColor`类进行...

Global site tag (gtag.js) - Google Analytics