函數(shù)要多小才夠好——談小函數(shù)之道

2018-06-16 18:28 更新

“設(shè)計(jì)良好的函數(shù)往往比較小,而過大函數(shù)的設(shè)計(jì)往往一塌糊涂,或者存在很大的優(yōu)化空間?!?/p>

也許你認(rèn)為討論函數(shù)的大小沒有必要,原因是函數(shù)設(shè)計(jì)的本質(zhì)是內(nèi)聚,它的大小只是它的表現(xiàn)形式。 而上面的原因有必要讓我們討論一下函數(shù)的大小問題。

我對函數(shù)的核心思路:我提出代碼最小處理單元的概念:一個(gè)基本操作(賦值,比較等),一個(gè)函數(shù)調(diào)用(包括調(diào)用后判斷返回值進(jìn)行判斷)都看成一個(gè)最小處理單元。 那么,一個(gè)函數(shù),最小處理單元合理的個(gè)數(shù)范圍在7以內(nèi)。 如果超過了7,你就要考慮把他們拆分成多個(gè)函數(shù)了(為什么是7?人同時(shí)能夠處理的信息不超過7個(gè))。

最小數(shù)目沒有限制,即便是只有1個(gè),也有存在的必要

在下面的情況下我會將函數(shù)拆分為更小的函數(shù):

1、一眼不能夠看到函數(shù)所有的代碼。

如果函數(shù)過長,無法一眼看到一個(gè)函數(shù)所有的代碼,我會毫不猶豫的拆分。 我不想讓讀者去翻屏,也不想讓讀者前顧后盼,顧此失彼。 漂亮的函數(shù)應(yīng)該讓讀者一眼就知道他在做什么以及怎么做的

2、局部變量過多。

如果局部變量超過七個(gè),我會考慮拆分函數(shù)。 變量過多意味著我要記錄太多的狀態(tài),這會加重我大腦的負(fù)擔(dān),同時(shí)要考慮太多的東西。 這也同時(shí)意味著我可能沒有對函數(shù)功能進(jìn)行深入的思考。

3、太多的縮進(jìn)。

太多的縮進(jìn)意味著太多的嵌套,要么是循環(huán),要么是判斷,都會導(dǎo)致復(fù)雜的邏輯。

4、不處于同一抽象層次。

舉例,有一個(gè)初始化函數(shù),需要初始化配置數(shù)據(jù),套接字,數(shù)據(jù)庫連接,通道狀態(tài)。

Void init()
{
    Config_init();
    Socket_init();
    Db_init();
    Int I = 0;

    For (I = 0;I < max_chn_num;i++)//初始化所有通道
    {
        G_user_chn[i].status = status_init;
        ……
    }
}

上個(gè)函數(shù)中對所有通道的初始化一塊代碼就和其他的不處于一個(gè)抽象層次,我們應(yīng)該將它封裝起來:

void chn_init()
{
    Int I = 0;

    For (I = 0;I < max_chn_num;i++)//初始化所有通道
    {
        G_user_chn[i].status =status_init;
        ……
    }
}

函數(shù)最小可以有多小,它存在的意義

我見過的最優(yōu)秀的函數(shù):

int max(int a, intb)
{
    return a > b?a:b;
}

這個(gè)函數(shù)很小,只有一行,但是他存在的意義在于:在函數(shù)的調(diào)用點(diǎn),我們一眼就知道是獲取a和b中的最大值,而不是分析 a > b?a:b 的邏輯。 這樣可以節(jié)省程序員的腦力成本,從而達(dá)到一個(gè)目的:漂亮的函數(shù)應(yīng)該讓讀者一眼就知道他在做什么以及怎么做的

最后的建議:

在對新員工培訓(xùn)的過程中,發(fā)現(xiàn)程序員新手一般對函數(shù)的大小不夠敏感。 所以,我建議你可以多嘗試編寫10行左右(甚至更小)的函數(shù),慢慢你會發(fā)現(xiàn)小函數(shù)原來具有大威力。

原文:http://justjavac.com/other/2012/05/29/to-use-little-function.html

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號