C++和Python使用同一個枚舉的方法
來源:互聯網
上載者:User
C++和Python使用同一個枚舉的方法為了能快速修改程式的邏輯,我在C++ 程式中使用了 Python作為指令碼。
程式內部需要接收指令碼傳過來的一些不同類型的訊息,在C++ 程式中使用了枚舉來區分這些訊息。 於是編寫指令碼時想到:
如何能在Python中也使用這些枚舉?如何只維護一個檔案?
1.Python中沒有枚舉類型,所以打算在檔案中直接寫一些變數並賦值:
ENUM_VALUE1 = 1
ENUM_VALUE2 = 2
...
2.C++中的變數必須聲明,所以只能使用枚舉或宏定義,但是"#"在Python中是注釋,所以只能使用枚舉,所以我打算將定義檔案寫成上面那種形式(假設檔案名稱:"Micro.py"),然後C++中:
enum
{
#include "Micro.h"
}
但是 enum 中的每個定義後面都應該有逗號",",要不然C++中就無法編譯通過了,所以我加入另一個檔案"Comma.h",檔案中只有一個逗號",",然後把定義檔案修改成這樣:
ENUM_VALUE1 = 1
#include "Comma.h"
ENUM_VALUE2 = 2
#include "Comma.h"
...
3.我們的定義檔案中還應該有注釋內容,要不然別人就看不懂這些定義到底代表啥意思了,考慮到C++中的注釋用"//",Python中的注釋用"#",而"#"在C++中是編譯預先處理指令的開始,所以我又把定義檔案改寫成這樣:
#define _C_PY_DESCRIBE1 "宏定義描述1"
ENUM_VALUE1 = 1
#include "Comma.h"
#define _C_PY_DESCRIBE2 "宏定義描述2"
ENUM_VALUE2 = 2
#include "Comma.h"
...
結束了,呵呵,雖然很變態,但是至少實現了宏定義的統一;
其他:
1.副檔名只能儲存為".py",所以C++中看不到文法高亮了。
2.如果注釋中包含中文,那麼宏定義檔案應該儲存為utf8格式,否則Python會提示未聲明解碼方式。