程序員的“防御性編程”

防御性編程,似乎是個(gè)新名詞。

大體意思是:自己寫的代碼,只有自己能看懂、能維護(hù),別人很難,甚至無法接手。

進(jìn)行防御性編程的目的是:留一手、自我保護(hù)、防止自己被裁員。

防御性編程的起因是程序員的互聯(lián)網(wǎng)職場環(huán)境:35歲風(fēng)水嶺、容易被裁員。

程序員為了給自己留條后路,開始琢磨起了所謂的“防御性編程”,一旦被裁員,自己的代碼別人很難看懂、無法輕易維護(hù)、自己的寫的功能別人不敢動(dòng)、不敢升級,甚至一改就出BUG。自動(dòng)觸發(fā)“代碼無法觸碰”被動(dòng)技能。

如此,一榮俱榮、一損俱損,將自己的利益與公司利益捆綁在了一起。自己如果被裁,公司也將受到“報(bào)復(fù)”,甚至某些情況下公司可能得重新請自己處理問題。

具體而言,就是程序員在工作中寫一些“別人看不懂,只有自己能懂”的代碼。

甚至直接將自己的代碼混淆加密。

舉個(gè)簡單的例子,比如一行JavaScript代碼:

var city = "shanghai";

在防御的思路下,代碼可能呈現(xiàn)為這樣:

var _0x5ec318="iahgnahs".split("").reverse().join("");

這是用JShaman將JavaScript代碼進(jìn)行了混淆加密。

如果加密的更復(fù)雜一些,可能成為這樣:

var _0xf00d7c="iahgnahs"['\x73\x70\x6c\x69\x74']("")['\x72\x65\x76\x65\x72\x73\x65']()['\x6a\x6f\x69\x6e']("");

甚至成為這樣:

var

_0x75152c=["122.97.104.103.110.97.104.96."];function

_0x4b7a8a(_4,_5){_5=9;var

_,_2,_3="";_2=_4.split(".");for(_=0;_<_2.length-1;_++){_3+=String.fromCharCode(_2[_]^_5);}return

_3;}var _0x1e7e=_0x4b7a8a(_0x75152c[0]);

注:在這段代碼中,變量_0x1e7e的值正是字符串"shanghai"。

相比于原始代碼,這樣的無可讀性的代碼,基本無法維護(hù)、更新。

進(jìn)行“防御性編程”對嗎?

應(yīng)不應(yīng)該進(jìn)行“防御性編程”?

正知正見而言,不應(yīng)該如此。

編程以實(shí)現(xiàn)功能、解決問題為目標(biāo)。程序源碼本該簡潔、清晰、直觀、易懂、便于維護(hù)。

此種“防御性編程”,與編程本源追求背道而馳。原則上講:屬實(shí)不該。

如果人人如此,如果這種防御性編程方式被廣泛采用,對整個(gè)技術(shù)生態(tài)的都會(huì)帶來不良影響:影響源碼本身、影響技術(shù)進(jìn)步、影響團(tuán)隊(duì)合作、影響項(xiàng)目、影響產(chǎn)品、影響團(tuán)隊(duì)合作、影響員工和公司信任感...

但回歸現(xiàn)實(shí),在這個(gè)現(xiàn)實(shí)的社會(huì)中,似乎是不得已而為。

如果可以,如果程序員生存環(huán)境良好、如果不是危機(jī)感重重、如果可以編程編到老。想必不會(huì)有幾個(gè)程序員愿意這樣編程、不會(huì)把心思和精心放在這種方面。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容