精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一個(gè)BUG的發(fā)現(xiàn)、定位和解決

移動(dòng)開(kāi)發(fā) iOS
在iOS 11發(fā)布之后,出現(xiàn)了一系列適配相關(guān)的問(wèn)題,UIScrollView在pagingEnabled=YES時(shí)滑動(dòng)手勢(shì)不靈敏,UITableView的滑動(dòng)刪除功能變動(dòng),UIImagePickerViewController的取消按鈕點(diǎn)擊區(qū)域變小等,本文介紹其中一個(gè)UIAlertView問(wèn)題,分享其發(fā)現(xiàn)、定位和解決。

前言

在iOS 11發(fā)布之后,出現(xiàn)了一系列適配相關(guān)的問(wèn)題,UIScrollView在pagingEnabled=YES時(shí)滑動(dòng)手勢(shì)不靈敏,UITableView的滑動(dòng)刪除功能變動(dòng),UIImagePickerViewController的取消按鈕點(diǎn)擊區(qū)域變小等,本文介紹其中一個(gè)UIAlertView問(wèn)題,分享其發(fā)現(xiàn)、定位和解決。

正文

1、問(wèn)題產(chǎn)生

問(wèn)題的最初,是iOS 11正式版發(fā)布后不久,測(cè)試的同學(xué)提了一個(gè)iOS 11相關(guān)的BUG,表現(xiàn)是:在直播間內(nèi)發(fā)送聊天信息,如果被禁言,會(huì)彈出“被禁言”提示,鍵盤(pán)收回去,然后就彈不出來(lái)。

開(kāi)發(fā)在接到這個(gè)BUG的時(shí)候,先把問(wèn)題抽象出來(lái)幾個(gè)要素:直播間內(nèi)、鍵盤(pán)彈出、彈出提示、鍵盤(pán)收回、鍵盤(pán)無(wú)法彈出。

彈出提示是用的UIAlertView的方式。在鍵盤(pán)出現(xiàn)時(shí)彈出UIAlertView的提示,鍵盤(pán)會(huì)收起,UIAlertView消失后,鍵盤(pán)會(huì)再次彈出,是一次正常的表現(xiàn)。

2、問(wèn)題復(fù)現(xiàn)

按照復(fù)現(xiàn)路徑做一次嘗試,發(fā)現(xiàn)BUG可以復(fù)現(xiàn),確定問(wèn)題存在;

  • 根據(jù)經(jīng)驗(yàn),猜測(cè)問(wèn)題可能出現(xiàn)在鍵盤(pán)和UIAlertView上,與“禁言”的業(yè)務(wù)無(wú)關(guān)。
  • 在直播間內(nèi)嘗試其他非“禁言”的場(chǎng)景,同樣是在鍵盤(pán)出現(xiàn)的時(shí)候,彈出UIAlertView的提示,也會(huì)造成后續(xù)鍵盤(pán)無(wú)法彈出的情況。

在嘗試完其他非直播間的主場(chǎng)景之后,發(fā)現(xiàn)問(wèn)題可以描述為:

  • iOS 11的機(jī)器只要彈出來(lái)一次UIAlertView,之后再通過(guò)becomeFirstResponder無(wú)法呼起鍵盤(pán);必須手動(dòng)點(diǎn)擊輸入?yún)^(qū)域,觸發(fā)系統(tǒng)的鍵盤(pán)彈出行為,或者切入后臺(tái)再切回來(lái),才能正常彈出來(lái)鍵盤(pán)。
  • 部分頁(yè)面在點(diǎn)擊評(píng)論后,會(huì)添加一層透明maskView,并彈出鍵盤(pán)。點(diǎn)擊透明的maskView會(huì)調(diào)用resignFirstResponder,在鍵盤(pán)消失的notification中消除maskView。因?yàn)殒I盤(pán)無(wú)法彈出(也無(wú)法收到鍵盤(pán)消失的notification,但maskView還是正常添加),導(dǎo)致這部分頁(yè)面無(wú)法進(jìn)行后續(xù)的交互。

3、問(wèn)題評(píng)估

  • 在復(fù)現(xiàn)問(wèn)題后,需要對(duì)問(wèn)題的嚴(yán)重性進(jìn)行評(píng)估,確定BUG修復(fù)的優(yōu)先級(jí)。
  • 從已知的表現(xiàn)來(lái)看,iOS 11下的使用影響較大(UIAlertView的提示較多)。
  • 用iOS 11的機(jī)器下載外網(wǎng)版本進(jìn)行測(cè)試,發(fā)現(xiàn)BUG竟然無(wú)法復(fù)現(xiàn)!
  • 雖然很詭異,但是問(wèn)題的優(yōu)先級(jí)可以降到更低,排入正常的BUG解決列表中。

4、問(wèn)題解析

外網(wǎng)版本是Xcode8編譯的本,本地版本使用的Xcode9 GM編譯的,難道是Xcode 9編譯導(dǎo)致?

  • 新建一個(gè)demo,只有輸入框和按鈕,模擬UIAlertView彈出,發(fā)現(xiàn)demo是正常的;
  • 把a(bǔ)pp的工程設(shè)置復(fù)制到demo,把對(duì)輸入框的屬性設(shè)置同樣復(fù)制到demo,demo依舊正常;
  • 把demo代碼復(fù)制到app,并把a(bǔ)pp的rootViewController賦值為demo中的VC,依舊正常;

可以確定是app中某部分代碼導(dǎo)致的鍵盤(pán)無(wú)法彈出的。

經(jīng)過(guò)二分注釋的方式,迅速(4、5次左右)定位到問(wèn)題是app中的某個(gè)Service類(lèi)導(dǎo)致。

仔細(xì)排插Service類(lèi)的屬性,發(fā)現(xiàn)里面有一個(gè)屬性的是繼承UIWindow并且level比UIWindowLevelStatusBar高。

自此,根據(jù)所學(xué)和蘋(píng)果UIKit的文檔,我們可以對(duì)問(wèn)題進(jìn)行一次回溯。

5、問(wèn)題回溯

一個(gè)BUG的發(fā)現(xiàn)、定位和解決

蘋(píng)果官網(wǎng)上響應(yīng)鏈和UIWindow的說(shuō)明,里面關(guān)于becomeFirstResponder()的解釋是:

Asks UIKit to make this object the first responder in its window.

對(duì)于UIAlertView的iOS 11系統(tǒng)行為,猜測(cè):

  • 在UIAlertView彈出的時(shí)候,會(huì)搶占系統(tǒng)的keyWindow,所以會(huì)出現(xiàn)鍵盤(pán)在UIAlertView的時(shí)候收回(因?yàn)閗eyWindow改變);
  • 在UIAlertView消失的時(shí)候,會(huì)遍歷所有Window,找到其中z軸***作為keyWindow,所以會(huì)出現(xiàn)鍵盤(pán)在UIAlertView消失后彈出(keyWindow變成原來(lái)的);

通過(guò)寫(xiě)代碼調(diào)試app,確定了上面的猜測(cè)。

在iOS 11,如果UIAlertView彈出時(shí),存在windowLevel 大于 UIWindowLevelNormal 的UIWindow,就會(huì)觸發(fā)這個(gè)鍵盤(pán)無(wú)法彈出的BUG。

6、問(wèn)題修復(fù)

  • 保證app中,沒(méi)有常駐的UIWindow;
  • 修復(fù)鍵盤(pán)無(wú)法彈出時(shí),maskView無(wú)法消除的BUG;
  • UIAlertView在后續(xù)的版本替換掉;

總結(jié)

  • 這次問(wèn)題從產(chǎn)生、復(fù)現(xiàn)、定位、評(píng)估再到修復(fù)的時(shí)間,和寫(xiě)這篇文章的時(shí)間差不多。
  • BUG的解決流程各不相同,借此提醒自己對(duì)于BUG的解決要有目的性和優(yōu)先級(jí)。
責(zé)任編輯:未麗燕 來(lái)源: 簡(jiǎn)書(shū)
相關(guān)推薦

2022-04-06 08:47:03

Dubbo服務(wù)協(xié)議

2009-08-18 11:01:51

2018-01-29 21:56:28

Bug程序程序員

2024-10-23 16:11:07

調(diào)試bug定位

2021-04-22 07:47:47

JavaJDKMYSQL

2022-11-30 09:18:51

JavaMyBatisMQ

2009-03-05 11:40:31

ListBox開(kāi)發(fā)Silverlight

2018-11-22 15:07:17

代碼github程序

2009-09-14 17:08:02

WebFormView

2025-02-13 07:00:00

Dubbo-goJava服務(wù)端

2024-11-12 15:42:06

2023-09-21 23:08:36

MySQL數(shù)據(jù)庫(kù)死鎖

2009-08-26 17:53:31

C# DropDown

2021-10-08 07:50:57

軟件設(shè)計(jì)程序

2011-08-01 09:25:32

SQL Server數(shù)

2020-05-04 11:04:46

HTTP劫持寬帶

2024-04-22 00:00:01

Redis集群

2014-12-17 09:40:22

dockerLinuxPaaS

2022-05-16 08:42:26

Pandasbug

2019-08-01 12:59:21

Bug代碼程序
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

国产精品手机在线观看| 欧美另类videos| 影音先锋黄色网址| 一区二区三区四区在线观看国产日韩| 日韩午夜精品电影| 欧美精品一区免费| 在线观看麻豆| 成人深夜视频在线观看| 5566日本婷婷色中文字幕97| 18精品爽国产三级网站| 国产一区二区在线观| 精品日韩视频在线观看| 日韩视频在线免费播放| 色吊丝在线永久观看最新版本| 久久aⅴ国产欧美74aaa| 96精品视频在线| 国产午夜手机精彩视频| 伊人精品一区| 欧美成人三级在线| 国产超碰在线播放| heyzo高清国产精品| 国产精品久久99| 欧美理论一区二区| 女人18毛片水真多18精品| 美洲天堂一区二卡三卡四卡视频| 97香蕉久久夜色精品国产| 人与动物性xxxx| 性人久久久久| 精品国产99国产精品| 免费精品99久久国产综合精品应用| 一区二区电影免费观看| 亚洲午夜在线电影| 五月天男人天堂| jzzjzzjzz亚洲成熟少妇| 91在线小视频| 国产欧美一区二区视频| 国产人妖一区二区| 另类人妖一区二区av| 日本精品一区二区三区在线| 国产午夜福利片| 欧美色图首页| 久久777国产线看观看精品| 激情高潮到大叫狂喷水| 第一sis亚洲原创| 亚洲天堂影视av| 魔女鞋交玉足榨精调教| 日本中文字幕在线一区| 精品成人在线观看| 日韩黄色一区二区| 在线精品国产亚洲| 日韩美女一区二区三区| 精品国产一二区| 白嫩白嫩国产精品| 精品三级在线看| 97中文字幕在线观看| 日韩一区二区三区色| 日韩午夜av电影| 精品人妻人人做人人爽夜夜爽| 国产精品免费精品自在线观看| 欧美蜜桃一区二区三区| 粉色视频免费看| 四虎影视国产精品| 4438x亚洲最大成人网| 热久久久久久久久| 久久久91麻豆精品国产一区| 欧美一级久久久| av电影中文字幕| 理论片一区二区在线| 亚洲精品国产精品国产自| 黄色国产在线观看| 国产精品免费大片| 在线亚洲国产精品网| 欧美福利在线视频| 午夜欧美精品| 欧美一级大胆视频| 免费在线观看av的网站| 久久99精品久久久久久国产越南| 91免费看国产| 少妇高潮一区二区三区99小说| 91在线云播放| 亚洲精品高清视频| a黄色片在线观看| 香蕉影视欧美成人| 91av俱乐部| 精品中文字幕一区二区三区四区 | 久久精品久久久久久久| 日韩主播视频在线| 92国产精品久久久久首页| 成人久久久精品国产乱码一区二区 | 欧美性猛交xxxx富婆| 天天插天天操天天射| 国产精品美女久久久久人| 亚洲国产精品字幕| 黄色aaa视频| 91综合在线| 91av视频在线观看| 国产精品伦一区二区三区| 成人av资源在线| 亚洲一区bb| 国产在线精彩视频| 欧美精品久久久久久久多人混战| 97精品人妻一区二区三区蜜桃| 欧美中文一区二区| 欧美激情日韩图片| 伊人亚洲综合网| 成人午夜精品一区二区三区| 亚洲欧洲精品一区二区| 欧美aaaaa性bbbbb小妇| 欧美精品日韩综合在线| 欧美性xxxx图片| 欧美日韩精品一本二本三本| 国产精品第100页| 欧美 日韩 国产 成人 在线| 中文字幕日本不卡| 无码人妻丰满熟妇区毛片18| 亚洲精品一区二区三区在线| 日韩最新在线视频| 欧美一区二区三区网站| 国产91精品在线观看| 一区二区不卡在线视频 午夜欧美不卡'| av资源网在线播放| 欧美另类久久久品| 久久美女免费视频| 国产农村妇女精品一区二区| 亚洲在线免费视频| 午夜不卡视频| 在线免费观看不卡av| 韩国无码一区二区三区精品| 国产精品mv在线观看| 成人妇女免费播放久久久| 大片免费播放在线视频| 欧美日韩国产色| 午夜不卡久久精品无码免费| 欧美极品一区二区三区| 成人免费黄色网| 亚洲天天影视| 欧美年轻男男videosbes| 久久久久久成人网| 日本中文字幕不卡| 日本不卡在线播放| 亚洲综合电影| 国产一区二区三区网站| 成人一二三四区| 久久精品视频免费观看| 精品免费国产一区二区| 最新国产一区| 国产精品h在线观看| 免费a级毛片在线观看| 福利视频一区二区| www.av欧美| 日韩电影免费在线| 日韩欧美亚洲v片| 成人久久网站| 久久精品国产亚洲7777| 国产精品一区二区人人爽| 日韩毛片一二三区| 91精品国产三级| 黑丝一区二区三区| 好吊色欧美一区二区三区| 操人在线观看| 亚洲视频在线播放| 欧美成人一区二区视频| 日韩一区欧美一区| 久久发布国产伦子伦精品| 国产综合婷婷| 久久亚洲高清| 91国内外精品自在线播放| 中文字幕免费精品一区高清| 国产精品玖玖玖| 亚洲二区视频在线| 91成年人网站| 九九九久久久精品| 欧美日韩不卡视频| 亚洲综合伊人久久| 欧美精品色网| 久久精品日产第一区二区三区精品版| 欧美人体一区二区三区| 正在播放欧美一区| 国产伦精品一区二区三区免.费| 亚洲激情av在线| 污片免费在线观看| 天堂va蜜桃一区二区三区| 亚洲一区二区三区精品视频| 国产精品1区| 97av在线影院| 91porn在线观看| 精品免费国产一区二区三区四区| 久久精品国产成人av| 国产精品久线观看视频| 久久艹这里只有精品| 日韩午夜av| 亚洲最新在线| 欧美理伦片在线播放| 国产欧美日韩视频| 丰满诱人av在线播放| 夜夜躁日日躁狠狠久久88av| 国产成年妇视频| 国内成人精品2018免费看| 中文字幕日韩精品有码视频| 久久永久免费视频| 一区二区三区不卡视频| 自拍偷拍中文字幕| 国产精品1024| 99sesese| 国产亚洲一区在线| aaa免费在线观看| 亚洲电影男人天堂| av一区观看| 亚洲精品69| 国产成人自拍视频在线观看| 日本中文字幕中出在线| 伊人久久久久久久久久| 三级网站免费观看| 91精品欧美福利在线观看 | 欧美午夜电影网| 久久精品视频8| 中文字幕一区二区三区不卡| 亚洲 小说 欧美 激情 另类| 丁香亚洲综合激情啪啪综合| 最新天堂中文在线| 美日韩精品视频| 少妇av一区二区三区无码| 亚洲老妇激情| 正义之心1992免费观看全集完整版| 欧美久久香蕉| 国产精品一区二区三区精品| 黄色片免费网址| 国产精品九九| 91国在线高清视频| 婷婷综合久久| 一级二级三级欧美| 四虎国产精品免费观看| 先锋影音一区二区三区| 亚洲小说图片视频| 久久亚洲午夜电影| 日韩欧美四区| 久久一区二区三区欧美亚洲| 国产极品模特精品一二| 成人在线观看网址| 婷婷综合国产| 国产99午夜精品一区二区三区| 精品亚洲a∨一区二区三区18| 91精品国产综合久久香蕉| 欧美高清免费| 91网站在线看| 日韩精品亚洲专区在线观看| 亚洲一区制服诱惑| 中文一区二区三区四区| 97se国产在线视频| www.成人网| 国产在线播放一区二区| 日韩激情啪啪| 免费观看成人在线| 国产成人三级| 亚洲一区二区三区在线观看视频| 久久看人人摘| 佐佐木明希av| 伊人成人网在线看| 免费av观看网址| 久久亚洲欧美| 精品999在线| 激情综合五月天| 日韩视频免费直播| 91theporn国产在线观看| 欧美日本在线看| jlzzjlzz亚洲女人18| 日韩久久久精品| 三级黄视频在线观看| 国产一区二区三区直播精品电影 | 91精品短视频| 久久国产欧美精品| 国产毛片一区二区三区| 亚洲综合网中心| 在线观看日韩av电影| 日本黄色三级大片| 国产裸体美女永久免费无遮挡| 超薄肉色丝袜一二三| 国产欧美三级| 国产又猛又黄的视频| 久久99精品国产91久久来源| 国产农村妇女精品久久| 粉嫩一区二区三区在线看| 日韩片在线观看| 国产精品免费久久久久| 欧美精品久久久久性色| 欧美三级xxx| 一区二区三区免费在线| 亚洲精品在线三区| h视频在线播放| 欧美激情女人20p| 韩国精品主播一区二区在线观看| 成人黄色影片在线| 思热99re视热频这里只精品| 亚洲一卡二卡三卡| 99精品国产福利在线观看免费| 天天干天天干天天干天天干天天干| 国产成人亚洲综合a∨猫咪| 免费看污黄网站在线观看| 亚洲精品第1页| 欧美另类高清videos的特点| 精品国产一区二区精华| 欧美尤物美女在线| 2020国产精品视频| 国产专区精品| 日韩欧美一区二区三区四区五区| 国内精品久久久久久久97牛牛| 日韩中文字幕组| 成人午夜短视频| 乱h高h女3p含苞待放| 91国产成人在线| 污视频在线免费| 欧美精品一区二区三区国产精品| 欧美日韩精品免费观看视欧美高清免费大片| 91久久精品一区二区别| 欧美熟乱15p| 白嫩少妇丰满一区二区| 波多野结衣在线一区| 成人高潮免费视频| 91精品亚洲| 波多野结衣精品久久| 欧美成人自拍| 国产激情在线观看视频| 97se亚洲国产综合自在线| 国产在线观看你懂的| 日韩一区二区三区视频在线观看| a√在线中文网新版址在线| 欧洲亚洲免费视频| 欧美成人一区在线观看| 青青在线免费观看| 国产在线视频精品一区| 99久久久无码国产精品不卡| 在线这里只有精品| 三级国产在线观看| 91av在线精品| 婷婷五月色综合香五月| 黄色影院一级片| 91免费观看在线| 九一国产在线观看| 精品亚洲精品福利线在观看| 高清在线视频不卡| 国产精品久久久久久久久久久久冷| 亚洲综合婷婷| 免费不卡av网站| 亚洲黄色小说网站| 成人福利小视频| 精品国产一区二区三区在线观看| 国产成人a视频高清在线观看| 日本一区二区三区四区在线观看| 久久免费国产| 男人舔女人下部高潮全视频| 欧美视频在线一区二区三区 | 亚洲视频久久久| 亚洲最大在线视频| 粉嫩91精品久久久久久久99蜜桃| 亚洲精品国产精品国自产观看| 秋霞成人午夜伦在线观看| 黑人と日本人の交わりビデオ| 欧美无人高清视频在线观看| 日本中文字幕电影在线免费观看| 成人精品在线视频| 欧美国产另类| av网站有哪些| 色综合婷婷久久| 亚洲成人影院麻豆| 亚洲自拍在线观看| 在线欧美亚洲| 91中文字幕永久在线| 欧美视频一区二区在线观看| 色哟哟免费在线观看| 成人免费看片视频| 黑人一区二区| 午夜精产品一区二区在线观看的| 欧美日韩精品福利| 日本精品600av| 久久五月天婷婷| 久久国产剧场电影| 亚洲熟女www一区二区三区| 亚洲第一国产精品| 精品网站在线| 成人在线观看毛片| 2022国产精品视频| 91麻豆成人精品国产| 色综合久久悠悠| 国产亚洲一区二区三区啪| 涩涩网站在线看| 黄色成人av在线| 亚洲图片88| 久久久久久久久久久久久久久久av | 久久久久亚洲精品成人网小说| 日韩在线你懂的| 97超碰人人爽| 欧美日韩一区二区在线| 91在线视频| 久久久久一区二区三区| 男人的j进女人的j一区| 国产第100页| 精品国产欧美一区二区三区成人| 日韩高清影视在线观看| 欧美视频亚洲图片| 91久久一区二区|