0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

全局變量與全局訪問之間的差異

opkgjew ? 來源:PLC標準化編程 ? 作者:萬泉河0031 ? 2022-11-14 11:21 ? 次閱讀

簡單說,全局變量、局部變量是變量自身的身份。身份的不同是靠出生地決定的。而能否被全能局訪問,能被多大范圍空間訪問,即首篇文章中講到的作用域,是完全不同的概念。不能混而等同之。

然而,如果大家對寫程序并沒有什么原則目標, 只以完成設計任務為目的,以設備最終能跑起來為目的,這些概念不清楚也無所謂。尤其只在西門子平臺內談,沒有橫向的對比,就得不出更深刻的經驗。

所以,這個話題就放下了。估計當年的讀者們也都放下了,沒幾個人放在心上。

我自己最近在編寫《三菱PLC標準化煙臺方法》的書,在寫書的過程中,在做一些小例子來驗證功能。其中把西門子的程序移植到了GX WORKS2,寫完了GX2的章節(jié)。然后現在又把程序移植到GX WORKS3,為GX3的章節(jié)整理素材。就發(fā)現了問題。

簡單描述,就是原本在西門子程序中,有外部對FB塊內的靜態(tài)變量訪問,到GX2,也仍然這么做的。但移植到GX3時,發(fā)現了問題,編譯報錯。

經咨詢三菱標準化的學員,得到提醒, 說新的GX3平臺,靜態(tài)變量VAR多出來一個VAR_PUBLIC的類型,可以支持外部訪問。照著修改之后,果然沒問題了。

(很多人以為我做啥品牌的標準化方法,就一定要在掌握這個品牌全部的高精端的知識基礎上,其實恰恰相反, 我只是對標準化架構熟悉,而對這些具體品牌和軟件的使用,我反而時刻在跟學員們學習請教。)

我現在回過頭看我當年提出的問題,就很清楚了。靜態(tài)變量能被全局訪問,被很多人誤以為就是等同于全局變量,那是因為只在西門子的井底。當視界擴大到所有PLC品牌和平臺之后,就不一樣了。甚至GX2和GX3都不一樣。

GX2中VAR可以被全局訪問,而GX3中則不可以。

你總不能認為GX2中的VAR是全局變量,而GX3中的 VAR就不是全局變量了吧?

發(fā)現這個問題的起源的程序塊來自西門子官方庫BST,先后移植到GX2和GX3。而根源又是其設計的部分靜態(tài)變量要被WINCC訪問,即勾選了HMI/OPC可見的選項。

在PORTAL中,不管是否勾選,影響的只是WINCC訪問的權限,而在程序中FB外的訪問都是暢通無阻的。

我在上帝一篇中建議過加個開關,關掉被塊外部訪問的權限,現在看,GX3果然做到了。

而最近幾天,也有學員在開發(fā)自己的庫函數,跟我溝通相似的問題。問我與WINCC通訊相關的變量放在OUTPUT還是STATIC更合適的問題。

我給與的回答是,原則上來講,應該放到INOUT或者OUTPUT。而放到VAR STATIC是不合適的,不符合封裝的原則。比如我這次的移植,就出現了問題。

不能因為看到有西門子官方的例子程序這么做過,就理所當然的認為就是正確無誤的。他們的作者也是普通的工控工程師,也未必事事都嚴格規(guī)范。

而我很容易就從西門子官方出的《設計規(guī)范指南》中找到了理論依據。

其中的DA005規(guī)則:只通過形參交換數據

DA006規(guī)則:僅從塊內訪問靜態(tài)變量

5eb973dc-6273-11ed-8abf-dac502259ad0.png

有人會杠, 如果不讓從塊外訪問靜態(tài)變量, 那系統(tǒng)為啥要設計為可以訪問?

就如同我一直在推廣PLC中編程不要使用M全局變量的理論,有人杠我系統(tǒng)設計了就該允許使用一個邏輯。

答案是系統(tǒng)提供的功能是給非規(guī)范的程序準備的。未必所有程序,比如測試學習程序也需要完全遵守規(guī)范。

而倒過來說,如果系統(tǒng)提供的功能即符合規(guī)范規(guī)則,只要規(guī)范規(guī)則之外的用法系統(tǒng)即不允許。如我在GX3遇到的這樣。那么,連編程規(guī)范都不需要存在。西門子也不需要整理一個設計規(guī)范了。

你做的不對, 編譯都不通過,保存都亮紅燈的事,還需要寫在規(guī)范里面嗎?

規(guī)范里的所有違反規(guī)范的相反的做法,都是可以用的,無非是不規(guī)范而已。

所以,我們在GX3遇到的問題, 那些導致編譯錯誤的變量, 正確規(guī)范的數據類型應該是INOUT和OUTPUT。

有一些剛入門的工程師, 甚至連FB都不會用,從未用過的工程師,會看不懂我的這些文章,會質疑這些文章傳播的知識什么用,我不懂你這些道理,我甚至不需要用FB,不也照樣做出功能正常運行的設備嗎?

我借用某Z常說的一句話:“基礎不牢,地動山搖”。其實我不完全認同這個道理的?;A不牢,不會導致你地動山搖,你在入門級別的工作并不受影響。而恰恰反過來,如果基礎牢了, 會有更高的起飛的空間。

就好比,田徑運動員基礎的動作姿勢如果不標準,在校級運動會可能沒什么大的影響,照樣有可能獲得校運會冠軍。然而當到了更大的天地間,就會發(fā)現姿勢標準的重要性了。而等到了奧運會選手的級別,所有的運動員動作一定都是最標準的了。因為那是基礎的基本功。




審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • HMI
    HMI
    +關注

    關注

    9

    文章

    578

    瀏覽量

    48384
  • VaR
    VaR
    +關注

    關注

    0

    文章

    38

    瀏覽量

    11305
  • 靜態(tài)變量

    關注

    0

    文章

    13

    瀏覽量

    6638

原文標題:1112 【萬泉河】FB內靜態(tài)變量的使用

文章出處:【微信號:PLC標準化編程,微信公眾號:PLC標準化編程】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    建立更多的全局變量的時候,如何使得PROGRAM SIZE不增大呢?

    今天發(fā)現,建立更多的全局變量的時候,PROGRAM SIZE同時也增大了,如何使得PROGRAM SIZE不增大呢?我對全局變量的初始化無要求。
    發(fā)表于 05-15 06:30

    請問ucos中全局變量OSTime最終能累加到多少呢?

    在ucos-ii 中全局變量 OSTime 總是++請問最終能累加到多少呢? 若加到65530后 會自動歸零嗎?
    發(fā)表于 05-09 06:22

    請問stm32程序中如何優(yōu)化大量的編譯開關和全局變量?

    剛接手一個程序,發(fā)現里面存在大量的編譯開關和定義了大量的全局變量,感覺這些顯得很是臃腫,有什么方法可以優(yōu)化一下這些編譯開關和全局變量? 全局變量是一個個的標志位,有時候還會有條件嵌套。
    發(fā)表于 05-06 06:35

    你是不是也沒躲過這個坑?用了太多全局變量......

    全局變量太多有哪些弊端?該如何規(guī)避,以及如何管理全局變量等。一、全局變量太多有哪些弊端?真正做過項目的同學應該都能明白,項目中全局變量太多,會存在很多問題。這里給大家羅列一些太多
    的頭像 發(fā)表于 05-01 08:10 ?417次閱讀
    你是不是也沒躲過這個坑?用了太多<b class='flag-5'>全局變量</b>......

    全局變量太多有哪些弊端?

    隨著全局變量的增多,不同模塊的變量名可能會產生沖突或混淆,導致代碼難以理解和維護。同時,全局變量使得代碼中的依賴關系變得復雜,難以追蹤和理解。這增加了新開發(fā)人員的學習成本,也增加了修改和調試的難度。
    發(fā)表于 04-24 09:15 ?756次閱讀

    請問ModusToolbox下針對CYW20719B2編程,能否指定全局變量地址?

    請問ModusToolbox 下針對CYW20719B2編程,能否指定全局變量地址? 謝謝
    發(fā)表于 03-01 11:13

    請問core2里的程序可以直接使用core1里的全局變量嗎?

    如題,core2里的程序可以直接使用core1里的全局變量嗎?就是不同核之前可以直接通信嗎?是否還需要配置一些東西才能實現核間通信?
    發(fā)表于 02-20 08:05

    Tc38x中全局變量訪問只能是不帶cache的地址嗎?

    全局變量只能放置在不帶cache的地址么?
    發(fā)表于 02-06 08:17

    使用Tasking編譯器生成的map文件中找不到靜態(tài)全局變量的地址怎么解決 ?

    使用Tasking編譯器生成的map文件中找不到靜態(tài)全局變量的地址(變量在函數中已經使用),請問怎么解決
    發(fā)表于 02-06 07:21

    如何在嵌入式C編碼中規(guī)范變量

    防止外部文件的非正常訪問。直接使用其他模塊的私有數據,將使模塊間的關系逐漸走向“剪不斷理還亂”的耦合狀態(tài),這種情形是不允許的。 ◎ 避免局部變量全局變量同名。 說明:盡管局部變量
    的頭像 發(fā)表于 12-07 14:42 ?300次閱讀

    全局變量數組數據錯亂怎么解決?

    不知道是自己定義的全局變量太多了還是怎么了? 在執(zhí)行數組賦值的時候不同的全局變量會出現共用地址的問題,也就是明明在給A賦值但是B的值也一起變了?導致出現數據錯亂,不知有誰遇到過這種情況???
    發(fā)表于 11-06 08:19

    STM8L進入低功耗全局變量釋放的原因?

    做一項目,使用RTC鬧鐘喚醒功能喚醒,測試了兩個月,沒遇到全局變量釋放的情況。今天上午發(fā)現單片機不能在指定時間喚醒,仿真模式下找了原因,發(fā)現使用的數組在進入休眠后,十分鐘喚醒后,數組釋放掉了,數組是全局變量。 向大神請教原因。
    發(fā)表于 11-03 08:18

    C語言中定義全局變量時,如何在定義變量時就指定好變量的地址?

    請問,C語言中定義全局變量時,如何在定義變量時就指定好變量的地址?
    發(fā)表于 11-03 06:31

    在嵌入式的程序中是不是盡量少用全局變量

    用什么代替全局變量傳遞參數
    發(fā)表于 11-02 07:35

    嵌入式全局變量的初始化原理詳解

    全局變量的初始值,是在哪里賦值的?
    的頭像 發(fā)表于 10-27 10:15 ?1039次閱讀
    嵌入式<b class='flag-5'>全局變量</b>的初始化原理詳解