欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何在python中實現(xiàn)capl語言里的回調(diào)函數(shù)(推薦)

 更新時間:2022年08月08日 16:24:02   作者:jasonj33  
CAPL是一種程序語言,其中程序塊的執(zhí)行由事件控制,主要介紹了如何在python中實現(xiàn)capl語言里的回調(diào)函數(shù)及事件函數(shù)的作用,需要的朋友可以參考下

CAPL:回調(diào)函數(shù)

CAPL是一種程序語言,其中程序塊的執(zhí)行由事件控制。 這些程序塊被稱為事件程序。在事件程序中定義的程序代碼在事件發(fā)生時執(zhí)行。換句話說,事件程序就是事件函數(shù),當事件函數(shù)關(guān)聯(lián)的事件被觸發(fā)時,會自動執(zhí)行此事件函數(shù)函數(shù)體。事件函數(shù)也稱為回調(diào)函數(shù)

事件函數(shù)的標志就是關(guān)鍵字on,比如:

  • on key 表示當鍵盤按下小寫字母a時觸發(fā)此事件函數(shù)執(zhí)行
  • on message 表示當接收到消息時觸發(fā)此事件函數(shù)執(zhí)行
  • on start 表示當canoe軟件運行時觸發(fā)此事件函數(shù)執(zhí)行
  • on sysvar 表示系統(tǒng)變量值發(fā)生改變時觸發(fā)此事件函數(shù)執(zhí)行

還有很多此類函數(shù),你可以通過在capl文件的左側(cè)的導航欄里右擊插入不同類型的事件函數(shù)

事件函數(shù)

事件函數(shù)的作用是什么?

就是在程序運行期間,可以隨時監(jiān)控某種事件的發(fā)生,執(zhí)行對應(yīng)的操作。比如你想在can總線上監(jiān)測收到can消息0x11時獲取can消息數(shù)據(jù),就可以使用on message 0x11

on message 0x11
{
  byte msg_bytes[8];
  int i;
  for(i=0;i<8;i++)
  {
    msg_bytes[i] = this.byte(i);
  }
}  

那為什么把它稱為回調(diào)函數(shù)呢?

可能是雖然主程序里的代碼在從上往下按順序在執(zhí)行,但是在這期間只要觸發(fā)事件函數(shù)的條件發(fā)生改變,就會“回頭”執(zhí)行事件函數(shù)。當然,主程序和事件函數(shù)是異步執(zhí)行

這里有一些注意事項:

Simulation Setup仿真界面插入的Network Node網(wǎng)絡(luò)節(jié)點,加載的capl腳本是沒有主程序MainTest的
Test Modules和Test Units加載的capl腳本,是不允許使用system類型的事件函數(shù)的

system類型的事件函數(shù)不允許使用

Python:回調(diào)函數(shù)

python執(zhí)行回調(diào)函數(shù),是在調(diào)用某個函數(shù)時,把回調(diào)函數(shù)指針當作參數(shù)傳入要調(diào)用的函數(shù)中,在函數(shù)內(nèi)部調(diào)用回調(diào)函數(shù)

def OnEvent_1():
    print("callback up")

def TriggerFunc(fn):
    fn()

if __name__ == "__main__":
    TriggerFunc(OnEvent_1)

在執(zhí)行TriggerFunc()時,通過傳入OnEvent_1()函數(shù)指針作為參數(shù),在TriggerFunc()函數(shù)體內(nèi)部調(diào)用OnEvent_1()實現(xiàn)回調(diào)

所以,OnEvent_1()函數(shù)是回調(diào)函數(shù),執(zhí)行TriggerFunc()函數(shù)就可以看作觸發(fā)回調(diào)函數(shù)的條件

這里有兩個注意點:

函數(shù)指針是指向函數(shù)的指針變量,用函數(shù)名表示,不能有括號“()”
調(diào)用函數(shù)時函數(shù)名必須有括號“()”才能調(diào)用

capl中的事件函數(shù),有幾個特點:

  • 函數(shù)體和觸發(fā)條件定義明確
  • 無限循環(huán)監(jiān)測觸發(fā)條件是否觸發(fā)
  • 和主函數(shù)異步執(zhí)行

所以在python中想實現(xiàn)這些特點,可以這樣:

import time
import threading

def OnEvent_1(): # 事件函數(shù)1
    print("OnEvent_1 up")

def OnEvent_2(): # 事件函數(shù)2
    print("OnEvent_2 up")

class RegistEvents(): # 全局變量,存入事件函數(shù)指針和對應(yīng)的觸發(fā)條件
    registEvents = {} # 存入key:value,key是事件函數(shù)指針,value是觸發(fā)此事件函數(shù)的條件

def TriggerFunc(): # 異步函數(shù),用來監(jiān)測觸發(fā)條件是否觸發(fā),如果觸發(fā)就執(zhí)行對應(yīng)的函數(shù)
    currentRegistEvents = {} # 當前的事件和對應(yīng)條件存入這里
    for event in RegistEvents.registEvents.keys():
        currentRegistEvents[event] = RegistEvents.registEvents[event]
    while True:
        time.sleep(0.01)
        for event in RegistEvents.registEvents.keys():
            if currentRegistEvents[event] != RegistEvents.registEvents[event]:
                event()
                currentRegistEvents[event] = RegistEvents.registEvents[event]

if __name__ == "__main__":
    RegistEvents.registEvents[OnEvent_1] = 0 # 對事件函數(shù)OnEvent_1和它的條件進行委托
    RegistEvents.registEvents[OnEvent_2] = 0 # 對事件函數(shù)OnEvent_2和它的條件進行委托
    t = threading.Thread(target = TriggerFunc) # 對監(jiān)測觸發(fā)條件的函數(shù)創(chuàng)建線程,異步執(zhí)行
    t.start()
    time.sleep(1)
    RegistEvents.registEvents[OnEvent_1] = 1 # 觸發(fā)條件本來是0,現(xiàn)在設(shè)置為1
    RegistEvents.registEvents[OnEvent_2] = 1
    time.sleep(1)
    RegistEvents.registEvents[OnEvent_1] = 2 # 觸發(fā)條件本來是1,現(xiàn)在設(shè)置為2
    RegistEvents.registEvents[OnEvent_2] = 2

由于python中并沒有像capl中那樣對不同類型觸發(fā)的事件函數(shù)進行定義(on key/on message等),所以這里我們可以借鑒c sharp語言中的委托,定義委托,然后注冊事件,最后執(zhí)行

這里用一個字典來注冊(存入)事件和對應(yīng)的觸發(fā)條件,key是事件函數(shù)指針,value是觸發(fā)條件(其實是事件函數(shù)指針關(guān)聯(lián)的一個值)

為什么不是key是觸發(fā)條件,value是函數(shù)指針呢?

因為事件函數(shù)的觸發(fā)條件需要改變,而字典中的key寫入后是無法改變的,但是value是可以改變的,所以value作為觸發(fā)條件會更好

到此這篇關(guān)于如何在python中實現(xiàn)capl語言里的回調(diào)函數(shù)的文章就介紹到這了,更多相關(guān)python回調(diào)函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談opencv自動光學檢測、目標分割和檢測(連通區(qū)域和findContours)

    淺談opencv自動光學檢測、目標分割和檢測(連通區(qū)域和findContours)

    這篇文章主要介紹了淺談opencv自動光學檢測、目標分割和檢測(連通區(qū)域和findContours),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • Python必備基礎(chǔ)之閉包和裝飾器知識總結(jié)

    Python必備基礎(chǔ)之閉包和裝飾器知識總結(jié)

    都2021年了Python的閉包和裝飾器難道你還不會?今天就帶大家詳細總結(jié)一下Python閉包和裝飾器的相關(guān)知識,需要的朋友可以參考下
    2021-06-06
  • python在linux中輸出帶顏色的文字的方法

    python在linux中輸出帶顏色的文字的方法

    這篇文章主要介紹了python在linux中輸出帶顏色的文字的方法,僅在Linux系統(tǒng)中有效果,一般輸出在控制臺中,本文用在日志環(huán)節(jié),方便測試,需要的朋友可以參考下
    2014-06-06
  • pycharm?console?打印中文為亂碼問題及解決

    pycharm?console?打印中文為亂碼問題及解決

    這篇文章主要介紹了pycharm?console?打印中文為亂碼問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • Python函數(shù)的參數(shù)類型和使用技巧詳解

    Python函數(shù)的參數(shù)類型和使用技巧詳解

    這篇文章主要介紹了Python函數(shù)的參數(shù)類型和使用技巧詳解,函數(shù)指通過專門的代碼組織,用來實現(xiàn)特定功能的代碼段,具有相對的獨立性,可以被其他代碼重復調(diào)用,需要的朋友可以參考下
    2023-08-08
  • 基于PyQt5制作一個PDF文件合并器

    基于PyQt5制作一個PDF文件合并器

    PDF文件合并工具是非常好用可以把多個pdf文件合并成一個,本文將利用Python中的PyQT5模塊,制作一個簡易的PDF文件合并器,感興趣的可以了解一下
    2022-03-03
  • python3.7 sys模塊的具體使用

    python3.7 sys模塊的具體使用

    這篇文章主要介紹了python3.7 sys模塊的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-07-07
  • Python中的隨機函數(shù)random詳解

    Python中的隨機函數(shù)random詳解

    大家好,本篇文章主要講的是Python中的隨機函數(shù)random詳解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • python樹的雙親存儲結(jié)構(gòu)的實現(xiàn)示例

    python樹的雙親存儲結(jié)構(gòu)的實現(xiàn)示例

    本文主要介紹了python樹的雙親存儲結(jié)構(gòu),這種存儲結(jié)構(gòu)是一種順序存儲結(jié)構(gòu),采用元素形如“[結(jié)點值,雙親結(jié)點索引]”的列表表示,感興趣的可以了解一下
    2023-11-11
  • 如何提取python字符串括號中的內(nèi)容

    如何提取python字符串括號中的內(nèi)容

    這篇文章主要介紹了如何提取python字符串括號中的內(nèi)容問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05

最新評論