激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - 易語言 - 總結(jié)升級(jí)易語言支持庫保證向下兼容性

總結(jié)升級(jí)易語言支持庫保證向下兼容性

2022-02-22 15:56易語言教程網(wǎng) 易語言

在本文里小編給大家整理了關(guān)于升級(jí)易語言支持庫保證向下兼容性的知識(shí)點(diǎn)注意提防,需要的朋友們參考下。

易語言支持庫升級(jí)之后,要保證向下兼容性,主要是做到以下幾點(diǎn):

一:保證原有的易語言源程序(.e)能正常打開(兼容點(diǎn)1)、正常編譯(兼容點(diǎn)2)、編譯結(jié)果正確(兼容點(diǎn)3);

二:保證原有的易語言程序(.exe)能正常運(yùn)行(兼容點(diǎn)4)、運(yùn)行結(jié)果正確(兼容點(diǎn)5)。

這里說的“原有的易語言源程序”和“原有的易語言程序”是指,替換新版支持庫文件之前,使用舊版支持庫編寫的易語言源程序,和使用該源程序編譯生成的可執(zhí)行程序。

本文主要就此問題結(jié)合具體情況進(jìn)行分析和總結(jié)。

一,為支持庫增加一條命令

新增加的命令,必須放在所有原有命令的后面,否則將違反兼容點(diǎn)2和4,更無法保證兼容點(diǎn)3和5。這是因?yàn)?,在源程序和EXE中,記錄的都是命令的索引,一旦在中間插入一條命令,將導(dǎo)致后面的命令索引全變了,進(jìn)而導(dǎo)致非常嚴(yán)重的錯(cuò)位問題。只要記住,總是在所有命令的最后添加新的命令,就不會(huì)引入兼容性問題。具體到數(shù)據(jù)類型的成員方法,與上面的分種一致,因?yàn)樗彩鞘褂弥С謳熘形ㄒ坏娜趾瘮?shù)表的,但這里引入了一個(gè)新的細(xì)節(jié),有一個(gè)LIB_DATA_TYPE_INFO.m_pnCmdsIndex 用于指定方法在全局函數(shù)表中的命令索引,所以通過它可以調(diào)整各成員方法的順序,這種做法通常不會(huì)引入兼容性問題。

二,為命令增加一個(gè)參數(shù),或修改命令的參數(shù)

新增加的參數(shù),必須放在所有參數(shù)的后面,否則將違反兼容點(diǎn)2,3,4,5;必須允許省略該參數(shù)(AS_DEFAULT_VALUE_IS_EMPTY)或該參數(shù)有默認(rèn)值(AS_HAS_DEFAULT_VALUE);同時(shí)在編寫代碼讀取該參數(shù)值時(shí)要小心,須判斷nArgCount和MDATA_INF.m_dtDataType(否則違反兼容點(diǎn)4,5),大致大代如下:

void fn_Global_SetWindowRgn (PMDATA_INF pRetData, INT nArgCount, PMDATA_INF pArgInf) { int nArg1 = pArgInf[0].m_int; int nArg2 = pArgInf[1].m_int; //假設(shè)第三個(gè)參數(shù)是新版添加的參數(shù) int nArg3 = 0; if(nArgCount > 2 && pArgInf[2].m_dtDataType != _SDT_NULL) { nArg3 = pArgInf[2].m_int; } //... }

修改一個(gè)已有命令的參數(shù)時(shí),不能隨便修改數(shù)據(jù)類型,否則將違反兼容點(diǎn)2,3,4,5,要改也只能改成通用型(同時(shí)在代碼中根據(jù)參數(shù)傳遞來的真實(shí)類型(MDATA_INF.m_dtDataType)做相應(yīng)處理)。參數(shù)的名稱和說明,因?yàn)槎际俏谋?,可以隨便改,有會(huì)有兼容性問題,但不要改的意思與原來相反哦(排除原來失誤寫反了的情況),改變參數(shù)語義往往會(huì)導(dǎo)致代碼改動(dòng),進(jìn)而導(dǎo)致違反兼容點(diǎn)5。

三,為窗口組件增加屬性

新增加的屬性,必須放在已有屬性的后面,否則違反兼容點(diǎn)4,5,因?yàn)橐渍Z言運(yùn)行時(shí)是通過屬性的索引讀寫屬性值的。然后在序列化屬性值時(shí),提高一個(gè)版本號(hào),讀取時(shí)先判斷版本,舊版序列化出的數(shù)據(jù)少,就不能多讀。在此提示,序列化屬性值時(shí),一定要先寫出版本號(hào),如果沒有版本號(hào),后續(xù)的兼容性問題多多。

(TODO:這一段另成一文)但即使有了版本號(hào),使用不當(dāng),也會(huì)導(dǎo)致升級(jí)時(shí)的麻煩,我前一段就遇到過,代碼有這么一句:if(dwVersion > CURRENT_VER) return FALSE; 版本號(hào)比現(xiàn)在能處理的版本號(hào)大,出現(xiàn)在什么情況呢,用舊版支持庫打開/運(yùn)行用新版支持庫編譯的易源程序/程序。返回假是合理的(畢竟不能完全處理這種情況),但是比較粗暴(這意味著無法用舊版支持庫打開用新版支持庫編寫的源程序/程序,這不是向下兼容的問題,是向上兼容的問題),如果能盡量讀取,放棄不能識(shí)別的數(shù)據(jù),溫和的處理,效果更好。簡(jiǎn)單的把這條判斷語句刪除,有用嗎?當(dāng)然沒用,舊版的支持庫已經(jīng)在用戶手上了,編譯結(jié)果是確定的,你的改動(dòng)只能體現(xiàn)在新版中,而對(duì)舊版無能為力。解決這個(gè)問題需要技巧,我采取的方案是,版本號(hào)不升反降!即,把CURRENT_VER減小,那么我序列化出的數(shù)據(jù),版本號(hào)比以前還小,舊版支持庫里的那條判斷(if(dwVersion > CURRENT_VER))就不起作用了,嘿嘿。新的序列化數(shù)據(jù)版本更低,但寫的數(shù)據(jù)更多,需要擔(dān)心舊版支持庫讀出多余的數(shù)據(jù)來嗎?當(dāng)然不用,舊版支持庫的編譯結(jié)果和運(yùn)行結(jié)果是確定的。只要新版支持庫中識(shí)別出這種情況,不要因?yàn)榘姹咎?hào)小就認(rèn)為是舊版就行了,同時(shí)后續(xù)升級(jí)的方便,再引入一個(gè)新的版本號(hào),存到原有序列化數(shù)據(jù)的最后,這樣再次升級(jí)時(shí)直接判斷新版本號(hào)就行了,原有的那套版本號(hào)停止使用。這一段有點(diǎn)亂,需整理。

四,為數(shù)據(jù)類型增加私有成員

如果某個(gè)數(shù)據(jù)類型已經(jīng)有了一個(gè)或多個(gè)私有成員,升級(jí)時(shí)需要增加一個(gè)私有成員,該怎么辦,直接在LIB_DATA_TYPE_ELEMENT 數(shù)組中添加一項(xiàng)嗎?不行!這樣將違反兼容點(diǎn)4,5,因?yàn)閷?duì)象所占用內(nèi)存是在由EXE分配的,舊的EXE中只為對(duì)象分配了N個(gè)成員的空間,而新庫要去訪問第N+1個(gè)成員,不就發(fā)生內(nèi)存訪問越界的錯(cuò)誤了嗎?解決方案是,把原來的N個(gè)私有成員連用新增加的成員,集中存儲(chǔ)到一塊新分配的內(nèi)存中,然后把這個(gè)內(nèi)存地址存儲(chǔ)到原有的第一個(gè)私有成員位置上(原有的其它成員位置廢棄不用)。因?yàn)榧词故桥fEXE也會(huì)調(diào)用新支持庫中的構(gòu)造函數(shù)和析構(gòu)函數(shù),所以改變私有成員存儲(chǔ)位置不會(huì)影響程序的執(zhí)行。這種方案對(duì)代碼的影響是非常大的,需要修改很多地方(所有對(duì)私有成員的讀寫),但是為了保證支持庫的向下兼容性,這種付出是值得的。

延伸 · 閱讀

精彩推薦
  • 易語言一步一步跟我學(xué)易語言之第二個(gè)易程序菜單設(shè)計(jì)

    一步一步跟我學(xué)易語言之第二個(gè)易程序菜單設(shè)計(jì)

    今天小編就為大家分享一篇關(guān)于的一步一步跟我學(xué)易語言之第二個(gè)易程序菜單設(shè)計(jì),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要...

    易語言幫助手冊(cè)7092021-06-17
  • 易語言易語言設(shè)置進(jìn)度條邊框樣式的方法

    易語言設(shè)置進(jìn)度條邊框樣式的方法

    今天小編就為大家分享一篇關(guān)于易語言設(shè)置進(jìn)度條邊框樣式的方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨...

    易語言幫助手冊(cè)4422022-01-20
  • 易語言易語言生成exe文件的方法

    易語言生成exe文件的方法

    在本篇內(nèi)容中小編給大家分享的是關(guān)于易語言生成exe文件的方法知識(shí)點(diǎn),需要的朋友們參考下。...

    易語言教程網(wǎng)14792022-03-01
  • 易語言一步一步跟我學(xué)易語言之關(guān)于變量

    一步一步跟我學(xué)易語言之關(guān)于變量

    今天小編就為大家分享一篇關(guān)于一步一步跟我學(xué)易語言之關(guān)于變量,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨...

    易語言幫助手冊(cè)10822021-06-17
  • 易語言易語言關(guān)于程序進(jìn)程和線程的基礎(chǔ)知識(shí)

    易語言關(guān)于程序進(jìn)程和線程的基礎(chǔ)知識(shí)

    今天小編就為大家分享一篇關(guān)于易語言關(guān)于程序進(jìn)程和線程的基礎(chǔ)知識(shí),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起...

    三葉資源網(wǎng)6662022-02-24
  • 易語言實(shí)例操作易語言載入窗口

    實(shí)例操作易語言載入窗口

    在本文中小編給大家整理的是關(guān)于易語言載入窗口的教程和步驟內(nèi)容,需要的可以跟著學(xué)習(xí)下...

    易語言教程網(wǎng)19162022-03-02
  • 易語言易語言在畫板中寫出指定文本當(dāng)畫板中已滿會(huì)自動(dòng)滾屏

    易語言在畫板中寫出指定文本當(dāng)畫板中已滿會(huì)自動(dòng)滾屏

    今天小編就為大家分享一篇關(guān)于易語言在畫板中寫出指定文本當(dāng)畫板中已滿會(huì)自動(dòng)滾屏,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,...

    易語言幫助手冊(cè)9092022-01-12
  • 易語言易語言獲取指定磁盤的名稱

    易語言獲取指定磁盤的名稱

    今天小編就為大家分享一篇關(guān)于易語言獲取指定磁盤的名稱,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來...

    易語言幫助手冊(cè)12662022-01-04
主站蜘蛛池模板: 成品片a免人视频 | 免费观看欧美一级片 | 欧美 国产 亚洲 卡通 综合 | 在线a毛片免费视频观看 | 一级在线免费观看视频 | 久久成人黄色 | 亚洲第一成人在线视频 | 国产精品久久久久国产精品三级 | 亚洲精品一区二区三区大胸 | 99久久九九爱看免费直播 | 亚洲国产精品一区二区三区 | 日本成人一区二区 | 久色精品视频 | 久久精品国产99国产精品亚洲 | 中文字幕亚洲视频 | 99爱视频在线观看 | 欧美女孩videos | 久久91精品久久久久清纯 | 中文字幕欧美日韩 | 免费久久久久久久 | 亚洲第一页中文字幕 | 亚洲综人网| 色羞羞 | av电影在线播放 | 亚洲网站在线播放 | 成人福利软件 | 色视频在线观看 | 视频一区二区在线观看 | 免费观看视频在线观看 | 婷婷久久综合九色综合色多多蜜臀 | 国产一级淫 | 国产乱淫av一区二区三区 | 欧美一级成人一区二区三区 | 久久96国产精品久久秘臀 | 成人国产高清 | 久久欧美亚洲另类专区91大神 | 久久国产精品网 | 国产九九热| 99欧美视频| 亚洲精品午夜国产va久久成人 | 欧美日韩在线视频一区 |