如何給軟件開發項目估價?

如何給軟件開發項目估價?
https://blog.coding.net/blog/How-to-estimate-the-program

作者:張海龍,CODING CEO,技術創業者。CMU計算機碩士,原 Oracle 高級軟件工程師。2010年回國創業,曾聯合創辦開源中國社區,2014年創辦 CODING。
Coding.net 是國內最大的一站式雲端開發平臺提供包括代碼託管,項目管理,產品演示,WebIDE 等工具,幫助軟件開發者提高生產效率,並實現 “Coding anytime anywhere” 的願景。Coding.net 目前已經積累了 25 萬開發者,37 萬項目,並且獲得了 IDG 和光速的兩輪投資共計 1500 萬美元。
2015年8月,CODING 推出 碼市,旨在通過雲端衆包的方式提高軟件交付的效率,幫助軟件開發行業實現高效的資源匹配。

“兄弟,你看做這樣一個軟件需要多少錢?” 這估計是所有軟件從業人員被問的最多也是最無奈的一個問題。這個問題等同於,“你看裝修一個100平米的房子需要多少錢?”。軟件開發你不懂,裝修你總懂吧,100平米的房子裝修從10萬到100萬均有可能,取決於你找什麼級別的設計公司,買什麼樣的材料,請什麼樣的施工隊……所以,我真的沒有辦法回答你“做這樣一個軟件需要多少錢?”的問題。

圖片

評估一個軟件開發的費用,你首先需要理清楚一些基本概念。

1. 招聘一個開發者的成本
如今(2015年) IT 行業蓬勃發展,對軟件開發工程師的需求很大,導致工程師的工資一路水漲船高,以一線城市爲例,一個能實際幹活的應屆開發者的月薪在10000元左右,3年以上工作經驗的基本能達到20000元。我們姑且把三年工作經驗定義爲靠譜的開發者,再加上其他福利和管理成本,一個靠譜全職開發者的成本在30000元左右。這還沒有算上你招聘的成本,想想是不是很肉疼?沒辦法,行情就是這樣,就跟這房價一樣。

2. 外包項目費用的計算方式
外包分爲兩種,人力外包和項目外包。人力外包是指外包公司派一個人去你公司工作,你按天支付這個人的費用給外包公司。目前這種外派的基本要價是1000元每天,好一點的人員在2000元以上。項目外包是指做完一個項目多少錢,不管外包公司投入多少人。有點類似於裝修隊的點工和包工。項目外包的價格雖然是打包價,但也是通過估算工時算出來的。例如一個項目預計需要兩個人開發20天,那就是40人天的工作量,按照1500元/人天算(這已經是良心價了),這個項目就是60000元。

看到這裏你一定會覺得,外包好貴,怎麼比招一個人的成本貴那麼多!君不見,用人除了硬性成本還有很多軟性成本的。例如招聘的時間成本,招來不合適開人的成本。而通過外包,你可以做到召之即來,揮之即去,這些軟性成本都是外包公司承擔了,你要算單價,自然會貴一些。

好了,下面我們回到正題,“開發這樣一個軟件需要多少錢?”。這裏的核心問題是如何定義“這樣”。你需要準確的估價,那就需要把需求定義清楚,否則估價就是耍流氓,最後一定導致糾紛。需求定義包含以下幾個方面:


1. 設計要求
一個好的設計是很貴的,因爲涉及到創意,而且不好評估,見仁見智。就跟你請大師畫一幅畫,還是請普通畫師畫一幅畫一樣,看你想要什麼了。在我看來,絕大部分軟件項目設計中規中矩就好了,請一個有經驗的設計師,按照最新流行的設計風格設計一套 UI 都不會差到哪裏去。而且價格都比較便宜的,一個 APP 的 UI 設計,一般在10000 - 20000之間,應該能有不錯的效果。當然,你對設計沒有要求的話,你找一個應屆生做一套 UI,幾千塊就搞定了,也不會太醜的。

2. 功能要求
我不止一次被問到,“我想做一個類似於微信的 APP……”,然後我就呵呵了。其實你不是真的想做一個微信,我相信你想要的只是微信的部分功能,例如聊天部分。所以你應該更加準確的描述你對功能的要求,例如:類似於微信的聊天功能,可以發文字,圖片,語音還有視頻,可以多人拉羣對話。有新消息會彈出通知,聊天記錄保存在服務器端……。在這一點上不能懶,你需要強迫自己去描述這些功能,你不要以爲你自己不懂就不去仔細思考,其實你可以的。有些功能看起來差不多,其實有很大的區別,比如聊天是否需要支持表情,表情是否支持動畫這些其實工作量都是很不一樣的。

3. 性能要求
性能問題其實不是特別需要關注,因爲在目前的技術發展水平上,性能都不會有太大的問題,特別是在項目初期,但也還是要說一說。同樣的功能,但是性能要求不一樣,工作量是完全不一樣的。還拿聊天來舉例子,這個功能是比較常見的,但是你說要像微信一樣支持幾億用戶同時聊天,那就是兩碼事了。同樣是個車,QQ和奔馳還是很不一樣的。

在明確了以上信息以後,你找一個有經驗的開發者或者項目監理就能給你一個明確的估價了。值得注意的是,軟件開發是一件非常不標準的事情,跟裝修很像,要留有餘地,你把費用卡的太死,最後別人只能偷工減料了。

當然還有一種估價方式,你先確定預算,然後再來定細節功能。例如你打算花50000來做一個 APP,具有類似微信的聊天功能,還有相互關注曬照片功能。你把詳細的功能需求給到開發者或者項目監理,他會去判斷你的預算能否實現你的要求,如果不能的話,你們再商量哪些功能可以先不做,例如聊天發表情功能不是很重要就先不做了,可以節約一些成本。

無論何種方式,都需要你明確需求,明確需求,明確需求!重要的事情說三遍。所以你找別人報價的時候,千萬不要只扔過去“開發一個類似於 xxxx 這樣的 APP 需要多少錢?”,你不會得到你想要的答案的,回答這樣的問題是不負責任的。不過,這倒不失爲一種過濾服務方的一種方法:)

(完)


*注:所有配圖來源於互聯網

2016.4.1 更新:我們已推出 碼市 自助評估系統,可根據不同的開發需求快速評估價格範圍和開發週期。該系統提取了超過 1000 個常見項目的報價方案,通過複雜嚴謹的算法和大量的反覆驗證,得出較爲合理的評價規則和體系,保證評估價格和週期的合理性及規範性。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章