JS 糟粕之全局变量和引用

广告位招租
扫码页面底部二维码联系

JS的全局变量是排第一的糟粕。比如:

【关注微信公众号:wwwtangshuangnet】【原创内容,转载请注明出处】【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。
const a = 1

function get() {
retun a
}

函数内可以直接使用一个函数外的变量,而且【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。可以层层往上引用。如果这个变量还是对象的【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。话,还可以修改对象。例如:

本文版权归作者所有,未经授权不得转载。原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.net
const o = { count: 0 }

function set(count) {
o.count = count
}

这种写法,由于我们写JS写的久了,觉得天【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。经地义,而且还是个与其他语言不同的特性(原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。优点),殊不知,这种东西,害人害己。

著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】

全局变量的设计,会使得内存引用及其复杂,未经授权,禁止复制转载。原创内容,盗版必究。且导致内存溢出。虽然js是自动回收垃圾,【关注微信公众号:wwwtangshuangnet】【本文首发于唐霜的博客】但是实际上很多情况下开发者需要自己手动释【原创不易,请尊重版权】【访问 www.tangshuang.net 获取更多精彩内容】放,而且由于全局变量这个特性,根本释放不【作者:唐霜】著作权归作者所有,禁止商业用途转载。了。

著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net【作者:唐霜】

如果要改进这门语言,我觉得可以学习rus未经授权,禁止复制转载。【转载请注明来源】t,去掉全局变量这种东西。

【转载请注明来源】【访问 www.tangshuang.net 获取更多精彩内容】【版权所有,侵权必究】
const a = 1
function get(&a) {
return a
}

const b = get(a) // b === a === 1
let b = a // a === null, b === 1

// ---------------

mut o = { count: 1 }
function set(mut &o, int count) {
o.count = count
}

function clone(o) {
return o
}
const n = clone(o)

虽然这使得这门语言麻烦很多,理解起来更复【版权所有,侵权必究】【原创不易,请尊重版权】杂,但是可以避免很多问题。

著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net【版权所有,侵权必究】【本文受版权保护】