[導(dǎo)讀]來(lái)源 :CSDN知識(shí)庫(kù)? 作為程序員,你是使用函數(shù)式編程還是面向?qū)ο缶幊谭绞剑?在本文中,擁有 10 多年軟件開(kāi)發(fā)經(jīng)驗(yàn)的作者從面向?qū)ο缶幊痰娜筇匦浴^承、封裝、多態(tài)三大角度提出了自己的疑問(wèn),并深刻表示是時(shí)候和面向?qū)ο缶幊陶f(shuō)再見(jiàn)了。 幾十年來(lái)我都在用
來(lái)源 :CSDN知識(shí)庫(kù)
作為程序員,你是使用函數(shù)式編程還是面向?qū)ο缶幊?/a>方式?
在本文中,擁有 10 多年軟件開(kāi)發(fā)經(jīng)驗(yàn)的作者從面向?qū)ο缶幊痰娜筇匦浴^承、封裝、多態(tài)三大角度提出了自己的疑問(wèn),并深刻表示是時(shí)候和面向?qū)ο缶幊陶f(shuō)再見(jiàn)了。
幾十年來(lái)我都在用面向?qū)ο蟮恼Z(yǔ)言編程。我用過(guò)的第一個(gè)面向?qū)ο蟮恼Z(yǔ)言是 C++,后來(lái)是 Smalltalk,最后是 .NET 和 Java。
我曾經(jīng)對(duì)使用繼承、封裝和多態(tài)充滿(mǎn)熱情。它們是范式的三大支柱。
我渴望實(shí)現(xiàn)重用之美,并在這個(gè)令人興奮的新天地中享受前輩們積累的智慧。
想到將現(xiàn)實(shí)世界的一切映射到類(lèi)中,使得整個(gè)世界都可以得到整齊的規(guī)劃,我無(wú)法抑制自己的興奮。
乍一看,繼承似乎是面向?qū)ο蠓妒降淖畲髢?yōu)勢(shì)。所有新手教程講解繼承時(shí)都會(huì)拿出最簡(jiǎn)單的繼承的例子,而這個(gè)例子似乎很符合邏輯。
然后就是滿(mǎn)篇的重用了。甚至以后的一切都是重用了。
我囫圇吞下這一切,然后帶著新發(fā)現(xiàn)興沖沖地奔向世界了。
帶著滿(mǎn)腔的信仰和解決問(wèn)題的熱情,我開(kāi)始構(gòu)建類(lèi)的層次結(jié)構(gòu)然后寫(xiě)代碼。似乎一切皆在掌控中。
我永遠(yuǎn)不會(huì)忘記我準(zhǔn)備從已有的類(lèi)繼承并實(shí)現(xiàn)重用的那一天。那是我期待已久的時(shí)刻。
后來(lái)有了新的項(xiàng)目,我想起了另一個(gè)項(xiàng)目里我很喜歡的那個(gè)類(lèi)。
沒(méi)問(wèn)題,重用拯救一切。我只需要把那個(gè)類(lèi)拿過(guò)來(lái)用就好了。
嗯……其實(shí)……不僅是那一個(gè)類(lèi)。還得把父類(lèi)也拿過(guò)來(lái)。但……應(yīng)該就可以了吧。
額……不對(duì),似乎還需要父類(lèi)的父類(lèi)……還有……嗯,我們需要所有的祖先類(lèi)。好吧好吧……搞定了。沒(méi)問(wèn)題。
不錯(cuò)。但編譯不過(guò),怎么回事?哦我知道了……這個(gè)對(duì)象還需要另一個(gè)對(duì)象。所以那個(gè)也得拿過(guò)來(lái)。沒(méi)問(wèn)題……
等等……我不僅需要那個(gè)對(duì)象,還需要那個(gè)對(duì)象的父類(lèi),和父類(lèi)的父類(lèi),和……包含的所有對(duì)象的所有祖先……
Erlang 的創(chuàng)建者 JoeArmstrong 有句名言:
面向?qū)ο笳Z(yǔ)言的問(wèn)題在于,它們依賴(lài)于特定的環(huán)境。你想要個(gè)香蕉,但拿到的卻是拿著香蕉的猩猩,乃至最后你擁有了整片叢林。
這個(gè)問(wèn)題的解決方法是,不要把類(lèi)層次建得那么深。但如果繼承是重用的關(guān)鍵,那么給繼承機(jī)制添加的任何限制都會(huì)限制重用。對(duì)吧?
那我們可憐的面向?qū)ο蟪绦騿T該怎么辦?指望一杯三聚氰胺奶維系我們的健康嗎?
答案就是:包含和委托(Contain and Delegate)。一會(huì)兒會(huì)詳細(xì)解釋。
早晚你會(huì)遇到下面這種惡心的問(wèn)題,有些語(yǔ)言甚至根本解決不了。
大多數(shù)面向?qū)ο笳Z(yǔ)言都不支持這種情況,盡管看上去似乎很符合邏輯。為什么面向?qū)ο笳Z(yǔ)言支持這種情況如此困難?
Class PoweredDevice {
}
Class Scanner inherits from PoweredDevice {
function start() {
}
}
Class Printer inherits from PoweredDevice {
function start() {
}
}
Class Copier inherits from Scanner, Printer {
}
注意 Scanner 和 Printer 類(lèi)都實(shí)現(xiàn)了名為 start 方法。
那么問(wèn)題來(lái)了,Copier繼承哪個(gè)start?是Scanner的還是Printer的?肯定不可能同時(shí)繼承啊。
沒(méi)錯(cuò)。大多數(shù)面向?qū)ο蠖疾蛔屇氵@么干。
但是,但是……要是必須這樣建模該怎么辦?我需要重用!
Class PoweredDevice {
}
Class Scanner inherits from PoweredDevice {
function start() {
}
}
Class Printer inherits from PoweredDevice {
function start() {
}
}
Class Copier {
Scanner scanner
Printer printer
function start() {
printer.start()
}
}
注意現(xiàn)在 Copier 類(lèi)包含一個(gè) Printer 實(shí)例和一個(gè) Scanner 實(shí)例。然后將 start 函數(shù)委托給 Printer 類(lèi)的實(shí)現(xiàn)。要委托給 Scanner 也很簡(jiǎn)單。
這個(gè)問(wèn)題是繼承這根支柱上的另一條裂縫。
好吧,那我盡量使用較淺的類(lèi)層次結(jié)構(gòu),并保證里面沒(méi)有環(huán),這樣就不會(huì)出現(xiàn)菱形繼承了。
似乎一切都解決了。直到我們發(fā)現(xiàn)……
我前一天工作得好好的代碼今天出錯(cuò)了!關(guān)鍵是,我沒(méi)有改任何代碼!
嗯也許是個(gè) bug……但等等……的確有些改動(dòng)……
但改動(dòng)的不是我的代碼。似乎改動(dòng)來(lái)自我繼承的那個(gè)類(lèi)。
為什么基類(lèi)的改動(dòng)會(huì)破壞我的代碼?
看看下面這個(gè)基類(lèi)(用Java寫(xiě)的,但就算你不懂Java,應(yīng)該也很容易看懂):
import java.util.ArrayList;
public
class
Array
{
private ArrayList<Object> a =
new ArrayList<Object>();
public void add(Object element)
{
a.
add(element);
}
public void addAll(Object elements[])
{
for (
int i =
0; i < elements.length; ++i)
a.
add(elements[i]);
// this line is going to be changed
}
}
重要提示:
注意加了注釋的那一行。稍后這行的改動(dòng)將會(huì)導(dǎo)致別的東西出錯(cuò)。
這個(gè)類(lèi)的接口上有兩個(gè)函數(shù):add() 和 addAll()。add() 函數(shù)負(fù)責(zé)添加一個(gè)元素,addAll() 函數(shù)會(huì)調(diào)用 add 函數(shù)添加多個(gè)元素。
public
class ArrayCount extends Array
{
private
int count =
0;
@Override
public void add(Object element)
{
super.add(element);
++count;
}
@Override
public void addAll(Object elements[])
{
super.addAll(elements);
count += elements.length;
}
}
ArrayCount類(lèi)是通用的Array類(lèi)的特化。兩者行為上的唯一區(qū)別就是ArrayCount會(huì)維護(hù)一個(gè)count,記錄元素的個(gè)數(shù)。
我們來(lái)仔細(xì)看看這兩個(gè)類(lèi)。
Array的add()給局部的ArrayList添加一個(gè)元素。
Array的addAll()針對(duì)每個(gè)元素調(diào)用局部的ArrayList的add方法。
ArrayCount的add()調(diào)用父類(lèi)的add()然后增加count。
ArrayCount的addAll()調(diào)用父類(lèi)的addAll()然后給count增加相當(dāng)于元素個(gè)數(shù)的數(shù)。
現(xiàn)在是出問(wèn)題的地方。基類(lèi)中加注釋的那行代碼現(xiàn)在改成這樣:
public void addAll(Object elements[])
{
for (
int i =
0; i < elements.length; ++i)
add(elements[i]);
// this line was changed
}
從基類(lèi)的作者的角度來(lái)看,這個(gè)類(lèi)實(shí)現(xiàn)的功能完全沒(méi)有變化。而且所有自動(dòng)化測(cè)試也都通過(guò)來(lái)了。
但是基類(lèi)的作者忘記了繼承的類(lèi)。而繼承類(lèi)的作者被錯(cuò)誤吵醒了。
現(xiàn)在ArrayCount的addAll()調(diào)用父類(lèi)的addAll(),后者在內(nèi)部調(diào)用add(),而add()被繼承類(lèi)重載了。
因此,每次繼承類(lèi)的add()被調(diào)用時(shí),count都會(huì)增加,然后在繼承類(lèi)的addAll()被調(diào)用時(shí)再次增加。
既然會(huì)發(fā)生這種現(xiàn)象,那么繼承類(lèi)的作者必須清楚基類(lèi)是怎樣實(shí)現(xiàn)的。而且,基類(lèi)的每個(gè)改動(dòng)必須要通知所有繼承類(lèi)的作者,因?yàn)檫@些改動(dòng)可能會(huì)以不可預(yù)知的方式破壞繼承類(lèi)。
唉!這個(gè)巨大的裂隙威脅到了整個(gè)繼承支柱的穩(wěn)定。
這個(gè)問(wèn)題還得要包含和委托來(lái)解決。
使用包含和委托,可以從白盒編程轉(zhuǎn)到黑盒編程。白盒編程的意思是說(shuō),寫(xiě)繼承類(lèi)時(shí)必須要了解基類(lèi)的實(shí)現(xiàn)。
而黑盒編程可以完全無(wú)視基類(lèi)的實(shí)現(xiàn),因?yàn)椴豢赡芡ㄟ^(guò)重載函數(shù)的方式向基類(lèi)注入代碼。只需要關(guān)注接口即可。
在面向?qū)ο笳Z(yǔ)言中實(shí)現(xiàn)包含和委托并不容易。它們是為了繼承方便而設(shè)計(jì)的。
如果你和我一樣,你就會(huì)開(kāi)始反思這個(gè)繼承了。但更重要的是,這些問(wèn)題應(yīng)當(dāng)引起你對(duì)于通過(guò)層次結(jié)構(gòu)進(jìn)行分類(lèi)的反思。
每到一個(gè)新公司時(shí),我都要為在哪兒保存公司文檔(即員工手冊(cè))而糾結(jié)。
是應(yīng)該建一個(gè)Documents文件夾,然后在里面建個(gè)Company呢?
還是應(yīng)該建個(gè)Company文件夾,然后在里面建個(gè)Documents呢?
兩者都可以。但哪個(gè)是正確的?哪個(gè)更好?
層次分類(lèi)的思想是因?yàn)榛?lèi)(父類(lèi))更通用,繼承類(lèi)(子類(lèi))更專(zhuān)用。沿著繼承鏈越往下走,概念就越專(zhuān)用(見(jiàn)上面的形狀層次)。
但如果父節(jié)點(diǎn)和子節(jié)點(diǎn)能隨意交換位置,那么顯然這種模型是有問(wèn)題的。
真實(shí)世界里有很多包含關(guān)系(或者叫做獨(dú)占關(guān)系)的層次結(jié)構(gòu)。
但你找不到層次分類(lèi)。仔細(xì)想一下。面向?qū)ο蠓妒绞歉鶕?jù)充滿(mǎn)了各種對(duì)象的真實(shí)世界建立的。但它用錯(cuò)了模型——層次分類(lèi)在真實(shí)世界中沒(méi)有類(lèi)比。
但真實(shí)世界里到處都是層次包含關(guān)系。層次包含關(guān)系的一個(gè)非常好的例子就是你的襪子。襪子放在裝襪子的抽屜里,然后抽屜包含在衣柜里,衣柜包含在臥室里,臥室包含在房子里,等等。
硬盤(pán)上的目錄也是層次包含關(guān)系的另一個(gè)例子——它們包含文件。
仔細(xì)想一下公司文檔,就會(huì)發(fā)現(xiàn)其實(shí)放在哪兒都無(wú)所謂。我可以放在Documents目錄下或者放在Stuff目錄下也可以。
我選擇的分類(lèi)法是標(biāo)簽。我給它加上不同的標(biāo)簽。
Document
Company
Handbook
標(biāo)簽是沒(méi)有順序或?qū)哟蔚模ㄟ@同時(shí)解決了菱形繼承問(wèn)題)。
標(biāo)簽可以類(lèi)比為接口,因?yàn)橥环菸臋n可以有多種類(lèi)型。
但既然有了這么多裂縫,估計(jì)繼承的支柱已經(jīng)倒塌了。
乍一看,封裝似乎是面向?qū)ο缶幊痰牡诙蠛锰帯?/span>
對(duì)象狀態(tài)變量被保護(hù)起來(lái)防止外部訪問(wèn),即它們被封裝在對(duì)象內(nèi)部。
我們不需要再操心那些可能被不知道誰(shuí)訪問(wèn)的全局變量。
為了提高效率,對(duì)象傳遞給函數(shù)時(shí)傳遞的是引用,而不是值。
也就是說(shuō),函數(shù)不會(huì)傳遞對(duì)象本身,而是傳遞指向?qū)ο蟮囊粋€(gè)引用或指針。
如果一個(gè)對(duì)象的引用被傳遞給另一個(gè)對(duì)象的構(gòu)造函數(shù),構(gòu)造函數(shù)就能將這個(gè)對(duì)象引用放到私有變量中,用封裝保護(hù)起來(lái)。
為什么不是?因?yàn)槠渌a也可能擁有指向該對(duì)象的指針,比如調(diào)用構(gòu)造函數(shù)的那段代碼。它必須有指向?qū)ο蟮囊?,否則沒(méi)辦法傳遞給構(gòu)造函數(shù)。
構(gòu)造函數(shù)必須要復(fù)制傳遞過(guò)來(lái)的對(duì)象。而且不能是淺復(fù)制,必須是深復(fù)制,即傳入的對(duì)象內(nèi)包含的所有對(duì)象和所有對(duì)象中包含的所有對(duì)象……都必須要復(fù)制。
而且更糟糕的是,并非所有對(duì)象都能復(fù)制的。一些擁有操作系統(tǒng)資源的對(duì)象,最好的情況是復(fù)制無(wú)效,最糟糕的情況是根本不可能復(fù)制。
所有主流面向?qū)ο笳Z(yǔ)言都有這個(gè)問(wèn)題。
多態(tài)是面向?qū)ο蟮娜灰惑w中永遠(yuǎn)被人拋棄的那一位。
不管他們?nèi)ツ膬憾紩?huì)帶著他,但他永遠(yuǎn)是配角。
并不是因?yàn)槎鄳B(tài)不好,而是因?yàn)閷?shí)現(xiàn)多態(tài)并不需要面向?qū)ο笳Z(yǔ)言。
接口也能實(shí)現(xiàn)多態(tài),而且不需要面向?qū)ο蟮呢?fù)擔(dān)。
而且,接口也不會(huì)限制你能混入的不同行為的數(shù)目。
所以,無(wú)需多言,我們可以告別面向?qū)ο蟮亩鄳B(tài),去迎接基于接口的多態(tài)吧。
當(dāng)然,面向?qū)ο笤谠缙诔兄Z了許多。而直到今天,這些承諾依然在教室里、博客上和網(wǎng)上資源中傳授給青澀的程序員們。
我花了多年才意識(shí)到面向?qū)ο蟮闹e言。以前我也曾經(jīng)青澀,曾經(jīng)輕信。
再見(jiàn),面向?qū)ο缶幊獭?/span>
去擁抱函數(shù)式編程吧。過(guò)去幾年我用得非常舒服。
但話說(shuō)在先,我并沒(méi)有給你做出任何承諾。眼見(jiàn)為實(shí)。
免責(zé)聲明:整理文章為傳播相關(guān)技術(shù),版權(quán)歸原作者所有,如有侵權(quán),請(qǐng)聯(lián)系刪除
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問(wèn)題,請(qǐng)聯(lián)系我們,謝謝!
欲知詳情,請(qǐng)下載word文檔
下載文檔
掃描二維碼,關(guān)注更多精彩內(nèi)容
本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。
關(guān)鍵字:
驅(qū)動(dòng)電源
在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過(guò)流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。
關(guān)鍵字:
工業(yè)電機(jī)
驅(qū)動(dòng)電源
LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問(wèn)題卻十分常見(jiàn),不僅增加了維護(hù)成本,還影響了用戶(hù)體驗(yàn)。要解決這一問(wèn)題,需從設(shè)計(jì)、生...
關(guān)鍵字:
驅(qū)動(dòng)電源
照明系統(tǒng)
散熱
電動(dòng)汽車(chē)(EV)作為新能源汽車(chē)的重要代表,正逐漸成為全球汽車(chē)產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車(chē)的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車(chē)的動(dòng)力性能和...
關(guān)鍵字:
電動(dòng)汽車(chē)
新能源
驅(qū)動(dòng)電源
在現(xiàn)代城市建設(shè)中,街道及停車(chē)場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...
關(guān)鍵字:
發(fā)光二極管
驅(qū)動(dòng)電源
LED
在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問(wèn)題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周?chē)娮釉O(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來(lái)解決L...
關(guān)鍵字:
LED照明技術(shù)
電磁干擾
驅(qū)動(dòng)電源
開(kāi)關(guān)電源具有效率高的特性,而且開(kāi)關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源
關(guān)鍵字:
LED
驅(qū)動(dòng)電源
開(kāi)關(guān)電源
LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。
關(guān)鍵字:
LED
隧道燈
驅(qū)動(dòng)電源
LED驅(qū)動(dòng)電源在LED照明系統(tǒng)中扮演著至關(guān)重要的角色。由于LED具有節(jié)能、環(huán)保、長(zhǎng)壽命等優(yōu)點(diǎn),使得LED照明在各個(gè)領(lǐng)域得到廣泛應(yīng)用。然而,LED的電流、電壓特性需要特定的驅(qū)動(dòng)電源才能正常工作。本文將介紹常用的LED驅(qū)動(dòng)電...
關(guān)鍵字:
LED驅(qū)動(dòng)電源
led照明
LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電源轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。
關(guān)鍵字:
LED
驅(qū)動(dòng)電源
高壓工頻交流
崧盛股份9日發(fā)布投資者關(guān)系活動(dòng)記錄表,就植物照明發(fā)展趨勢(shì)、行業(yè)壁壘等問(wèn)題進(jìn)行分享。植物照明未來(lái)市場(chǎng)需求廣闊崧盛股份指出,植物照明將會(huì)走向長(zhǎng)期產(chǎn)業(yè)領(lǐng)域。主要原因有三:第一,LED植物照明賦能終端種植更具有經(jīng)濟(jì)價(jià)值。由于LE...
關(guān)鍵字:
崧盛股份
驅(qū)動(dòng)電源
在當(dāng)今高度發(fā)展的技術(shù)中,電子產(chǎn)品的升級(jí)越來(lái)越快,LED燈技術(shù)也在不斷發(fā)展,這使我們的城市變得豐富多彩。 LED驅(qū)動(dòng)電源將電源轉(zhuǎn)換為特定的電壓和電流,以驅(qū)動(dòng)LED發(fā)光。通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流電(即...
關(guān)鍵字:
LED
驅(qū)動(dòng)電源
高壓直流
人類(lèi)社會(huì)的進(jìn)步離不開(kāi)社會(huì)上各行各業(yè)的努力,各種各樣的電子產(chǎn)品的更新?lián)Q代離不開(kāi)我們的設(shè)計(jì)者的努力,其實(shí)很多人并不會(huì)去了解電子產(chǎn)品的組成,比如LED電源。
關(guān)鍵字:
LED
驅(qū)動(dòng)電源
低壓直流
隨著科學(xué)技術(shù)的發(fā)展,LED技術(shù)也在不斷發(fā)展,為我們的生活帶來(lái)各種便利,為我們提供各種各樣生活信息,造福著我們?nèi)祟?lèi)。LED驅(qū)動(dòng)電源實(shí)際上是一種電源,但是它是一種特定的電源,用于驅(qū)動(dòng)LED發(fā)射帶有電壓或電流的光。 因此,LE...
關(guān)鍵字:
LED
驅(qū)動(dòng)電源
電流
LED燈作為一種新型節(jié)能和無(wú)污染光源,由于其特有的發(fā)光照明特性,在現(xiàn)代照明應(yīng)用中發(fā)揮著革命性的作用。作為 LED 照明產(chǎn)業(yè)鏈中最為核心的部件之一,LED 驅(qū)動(dòng)電源的驅(qū)動(dòng)控制技術(shù)所存在的可靠性低、成本高等典型問(wèn)題一直制約著...
關(guān)鍵字:
多路
LED
驅(qū)動(dòng)電源
隨著社會(huì)的快速發(fā)展,LED技術(shù)也在飛速發(fā)展,為我們的城市的燈光煥發(fā)光彩,讓我們的生活越來(lái)越有趣,那么你知道LED需要LED驅(qū)動(dòng)電源嗎?那么你知道什么是LED驅(qū)動(dòng)電源嗎?
關(guān)鍵字:
LED
開(kāi)關(guān)電源
驅(qū)動(dòng)電源
早前有新聞稱(chēng),Cree在2018年開(kāi)始宣布轉(zhuǎn)型高科技半導(dǎo)體領(lǐng)域,并一邊逐漸脫離照明與LED相關(guān)業(yè)務(wù),一邊持續(xù)投資半導(dǎo)體。在今日,Cree宣布與SMART Global Holdings, Inc.達(dá)成最終協(xié)議,擬將LED...
關(guān)鍵字:
cree
led照明