中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

iOS 11 BUG的發現、定位和解決

發布時間:2020-08-20 17:01:03 來源:腳本之家 閱讀:183 作者:落影loyinglin 欄目:移動開發

前言

在iOS 11發布之后,出現了一系列適配相關的問題,UIScrollView在pagingEnabled=YES時滑動手勢不靈敏,UITableView的滑動刪除功能變動,UIImagePickerViewController的取消按鈕點擊區域變小等,本文介紹其中一個UIAlertView問題,分享其發現、定位和解決。

正文

1、問題產生

問題的最初,是iOS 11正式版發布后不久,測試的同學提了一個iOS 11相關的BUG,表現是:在直播間內發送聊天信息,如果被禁言,會彈出“被禁言”提示,鍵盤收回去,然后就彈不出來。

開發在接到這個BUG的時候,先把問題抽象出來幾個要素:直播間內、鍵盤彈出、彈出提示、鍵盤收回、鍵盤無法彈出。

“彈出提示是用的UIAlertView的方式。在鍵盤出現時彈出UIAlertView的提示,鍵盤會收起,UIAlertView消失后,鍵盤會再次彈出,是一次正常的表現。”

2、問題復現

按照復現路徑做一次嘗試,發現BUG可以復現,確定問題存在;

根據經驗,猜測問題可能出現在鍵盤和UIAlertView上,與“禁言”的業務無關。

在直播間內嘗試其他非“禁言”的場景,同樣是在鍵盤出現的時候,彈出UIAlertView的提示,也會造成后續鍵盤無法彈出的情況。

在嘗試完其他非直播間的主場景之后,發現問題可以描述為:

iOS 11的機器只要彈出來一次UIAlertView,之后再通過becomeFirstResponder無法呼起鍵盤;必須手動點擊輸入區域,觸發系統的鍵盤彈出行為,或者切入后臺再切回來,才能正常彈出來鍵盤。

部分頁面在點擊評論后,會添加一層透明maskView,并彈出鍵盤。點擊透明的maskView會調用resignFirstResponder,在鍵盤消失的notification中消除maskView。因為鍵盤無法彈出(也無法收到鍵盤消失的notification,但maskView還是正常添加),導致這部分頁面無法進行后續的交互。

3、問題評估

在復現問題后,需要對問題的嚴重性進行評估,確定BUG修復的優先級。

從已知的表現來看,iOS 11下的使用影響較大(UIAlertView的提示較多)。

用iOS 11的機器下載外網版本進行測試,發現BUG竟然無法復現!

雖然很詭異,但是問題的優先級可以降到更低,排入正常的BUG解決列表中。

4、問題解析

外網版本是Xcode8編譯的本,本地版本使用的Xcode9 GM編譯的,難道是Xcode 9編譯導致?

1、新建一個demo,只有輸入框和按鈕,模擬UIAlertView彈出,發現demo是正常的;
2、把app的工程設置復制到demo,把對輸入框的屬性設置同樣復制到demo,demo依舊正常;
3、把demo代碼復制到app,并把app的rootViewController賦值為demo中的VC,依舊正常;

可以確定是app中某部分代碼導致的鍵盤無法彈出的。

經過二分注釋的方式,迅速(4、5次左右)定位到問題是app中的某個Service類導致。

仔細排插Service類的屬性,發現里面有一個屬性的是繼承UIWindow并且level比UIWindowLevelStatusBar高。

自此,根據所學和蘋果UIKit的文檔,我們可以對問題進行一次回溯。

5、問題回溯

iOS 11 BUG的發現、定位和解決

蘋果官網上響應鏈和UIWindow的說明,里面關于becomeFirstResponder()的解釋是:Asks UIKit to make this object the first responder in its window.

對于UIAlertView的iOS 11系統行為,猜測:

1、在UIAlertView彈出的時候,會搶占系統的keyWindow,所以會出現鍵盤在UIAlertView的時候收回(因為keyWindow改變);
2、在UIAlertView消失的時候,會遍歷所有Window,找到其中z軸最高作為keyWindow,所以會出現鍵盤在UIAlertView消失后彈出(keyWindow變成原來的);

通過寫代碼調試app,確定了上面的猜測。

在iOS 11,如果UIAlertView彈出時,存在windowLevel 大于 UIWindowLevelNormal 的UIWindow,就會觸發這個鍵盤無法彈出的BUG。

6、問題修復

1、保證app中,沒有常駐的UIWindow;
2、修復鍵盤無法彈出時,maskView無法消除的BUG;
3、UIAlertView在后續的版本替換掉;

總結

這次問題從產生、復現、定位、評估再到修復的時間,和寫這篇文章的時間差不多。

BUG的解決流程各不相同,借此提醒自己對于BUG的解決要有目的性和優先級。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

安义县| 宁阳县| 西盟| 图木舒克市| 成都市| 德江县| 利辛县| 富顺县| 岑巩县| 云南省| 乐业县| 洱源县| 攀枝花市| 囊谦县| 青川县| 遵义县| 望奎县| 迁安市| 安塞县| 巴塘县| 平安县| 九江县| 台中市| 疏勒县| 平潭县| 正蓝旗| 芒康县| 民县| 门头沟区| 郑州市| 辽阳市| 婺源县| 观塘区| 图木舒克市| 临清市| 芦山县| 贵港市| 钦州市| 晋州市| 峡江县| 阿尔山市|