《銷售態度》:質量保證、誠信服務、及時到位!
《銷售宗旨》:為客戶創造價值是我們永遠追求的目標!
《服務說明》:現貨配送至全國各地含稅(13%)含運費!
《產品質量》:原裝,*!均可質保一年,假一罰十!
《產品優勢》:專業銷售 薄利多銷 信譽好,口碑好,價格低,貨期短,大量現貨,服務周到!
以滿足客戶的需求為宗旨,以誠為本,精益求精
凡在本公司購買的產品,保證全新,假一罰十,可簽訂正式銷售合同,本公司主要經營S7-200,S7-300,S7-1200,S7-400 PLC模塊,觸摸屏,通訊電纜,編程電纜,DP接頭,LOGO,模快.SMART模塊,軟啟動器,伺服電機,變頻器等產品,西門子保內*產品‘質保一年。一年內因產品質量問題免費更換新產品;不收取任何費
S7-300PLC中的FB和FC的分別?FB帶有自己的背景DB而FC沒有自己的背景DB,用FC和FB有什么分別呢,他們都能實現控制功能,到底該用FB還是該用FC,什么時候用FB什么時候用FC?
FB與FC沒有太大的差別,FB帶有背景數據塊,而FC沒有。所以FB帶上不同的數據塊,就可以帶上不同的參數值。這樣就可以用同一FB和不同的背景數據塊,被多個對象調用。
FC和FB像C中的函數,只不過FB可以生成靜態變量,在下次函數調用時數據可以保留,而FC的變量只在調用期內有效,下次調用又重新更換。每次調用FC的I/O區域必須要自己每次手動輸入,而FB就不要,省去不少麻煩,如果在上位機控制直接輸入DB控制地址就可以。
舉個例子來說,有50臺電機需要控制,這些電機除了參數不一樣,控制流程上是一樣的,每個
電機需要不同的參數去運行,運行中的過程參數要參與到下一次的控制過程中。
這個要求,用FC做的話,你需要針對不同的電機分配好DB塊,來逐一的確認參數地址,不能混
淆,保存和調用不能出錯,可以想象會有多麻煩。如果用FB來做呢?寫好控制過程和定義的參
數的調用就可以了。針對電機重復調用同一個FB,每次調用一個獨立的DB作為背景數據塊
,*不必理會背景DB中的數據是怎么存儲的。如果功能需要修改,只要修改該FB就行了。
還有其他的例子,比如PID、比如流量累計等等。
fc就相當于流水線,加工完就過去了!沒有任何紀錄。fb+db不但可以加工,還能記錄數據的。
一般有多個設備的時候,我們編寫一個fb然后多次調用,自動生成相應的db,這樣簡化了我們
的工作。
FB的變量聲明表中有靜態變量,并可以進行多級的參數傳遞,因此在調用FB時需生成背景數據塊,
而FC則沒有這些.FB可以替代FC,反之則不行.
多級的參數傳遞即所謂的MULTIINSTANCE,你可以把FB,DB做為另外一個FB中的函數來調用,
如在FB2中可以使用FB1中的參數,而終只生成一個背景數據塊。
Zane:
FB其實不會占用過多的資源,因為一個程序總是有這些變量的,無論是全局的還是局部變量。
我現在,大量使用的是FB,FC只用來編一些邏輯,及簡單的子程序,或僅僅幾個CALL指令調用
FB。使用FB及局部變量,更有利于程序的模塊化,增加程序的可移植性,就象西門子公司提供的FB
塊.
其實FB和FC根本的區別是:FB支持靜態變量,而FC只支持臨時變量。
靜態變量:是調用FB返回時,仍然要為FB保留此變量區,因此不會改變這一區域的數據值。臨
時變量卻沒有這樣的特性。
所以在FC中如果在對臨時數據變量處寫入確定的數據前,就去讀時就可能產生不可預見的結果
,而對于靜態變量卻不會,因為它會保留你上次寫入的結果。
萬泉河:
咱們編制的控制程序,FB極少用到。所說的用FB來替代FC實用的情況,更是少見,有誰曾經把
FC全部用光啦?恐怕系統都不能負擔了。
提供的標準庫中,FB倒是不少的。
如果你要編制的函數沒有用到靜態變量,恐怕沒有必要使用FB吧?我看高級語言中,雖然靜態
變量使用很容易,但實際用也很少啊。
俠客:我和zane的觀點一樣,我工作中也是把相同功能的工作編制成FB,然后在FC里調用,程
序修改起來方便,舉個例子:如果你有10臺電機,一般我們都要給他編制啟動,停止邏輯,報
警,復位邏輯。如果我編一個FB把這些邏輯都做好了,為每一個電機分配一個背景數據塊的話
,我在FC調用這些電機時,我只要把這些電機對應的I/O點添到FB的管腳上就可以了,*不再
用考慮他里面的邏輯了,如果你全是用FC編這些邏輯的話,1、你要寫10遍,2、如果你用粘貼
和復制的話,有可能有的I/O點忘記修改或其他一些錯誤,3、程序的結構性不強,維護起來浪費
時間。