后續(xù)更新 | 減少使用非 SDK 接口以提升穩(wěn)定性

作者:?軟件工程師 David Brazdi 和 Nicolas Geoffray

在 Android 生態(tài)中,我們非常重視為用戶(hù)和開(kāi)發(fā)者提供最好的體驗(yàn)。每一次版本更新都會(huì)引入新的功能,助力開(kāi)發(fā)者打造完美的用戶(hù)體驗(yàn);然而,我們發(fā)現(xiàn)一些應(yīng)用開(kāi)發(fā)者在開(kāi)發(fā)過(guò)程中調(diào)用了非 SDK 接口,導(dǎo)致用戶(hù)頻繁遭遇應(yīng)用不兼容甚至崩潰,并給開(kāi)發(fā)者帶來(lái)緊急發(fā)布補(bǔ)丁等困擾。我們希望能做得更好,因此需要各位開(kāi)發(fā)者的共同協(xié)助,來(lái)確保每個(gè) Android 新版本的穩(wěn)定性。

三個(gè)月前,我們宣布從 Android P 開(kāi)始限制非 SDK 接口的使用。我們知道這些限制可能對(duì)您的應(yīng)用發(fā)布造成影響,因此我們?yōu)殚_(kāi)發(fā)者提供了相關(guān)工具用以檢測(cè)違規(guī)調(diào)用,幫助各位在計(jì)劃中預(yù)留充足時(shí)間,針對(duì)谷歌新發(fā)布的政策調(diào)整,并向我們提供反饋。

在開(kāi)發(fā)者預(yù)覽版和?Beta 1 版本中,我們通過(guò)多種方式告知了開(kāi)發(fā)者這些限制對(duì)應(yīng)用造成的影響。在開(kāi)發(fā)者預(yù)覽版中,被限制 API 的調(diào)用信息會(huì)被記錄在日志中,并顯示相應(yīng)的 Toast 警告;而在 Beta 1 版本中,開(kāi)發(fā)者可以通過(guò)使用StrictMode?檢測(cè)非 SDK 接口的調(diào)用,并自行記錄日志消息。比如:

我們理解應(yīng)用調(diào)用非 SDK 接口有很多原因,而確保您的應(yīng)用能夠繼續(xù)在 Android P 上順利運(yùn)行對(duì)我們而言非常重要。我們十分感謝很多開(kāi)發(fā)者通過(guò)錯(cuò)誤追蹤器?(issue tracker) 進(jìn)行反饋并詳細(xì)解釋對(duì)一些非 SDK 接口的需求。對(duì)于大部分的請(qǐng)求,我們已將相關(guān)的非 SDK 接口添加至灰名單,從而暫時(shí)豁免了它們?cè)?Android P 上的限制。同時(shí),我們團(tuán)隊(duì)也投入了大量資源,在百萬(wàn)個(gè)應(yīng)用上運(yùn)行靜態(tài)分析,同時(shí)處理數(shù)千份來(lái)自?xún)?nèi)外部 beta 測(cè)試人員的自動(dòng)生成報(bào)告。借助分析結(jié)果,我們識(shí)別出了更多應(yīng)用依賴(lài)的非 SDK 接口,并相應(yīng)地對(duì)灰名單進(jìn)行了增補(bǔ)。此外,我們將會(huì)在未來(lái)發(fā)布的系統(tǒng)版本中,探討是否存在公有 SDK 來(lái)替代灰名單中的接口。不過(guò),我們或許仍然漏掉了一些正在被使用的非 SDK 接口。因此,為了將應(yīng)用不兼容的風(fēng)險(xiǎn)降至最低,targetSdkVersion 為 Android Oreo 或更低的應(yīng)用依舊可以調(diào)用大部分非 SDK 接口。

總而言之,在 Android P 上運(yùn)行的應(yīng)用會(huì)受到非 SDK 接口使用限制。如果您的目標(biāo)版本為 Android P,請(qǐng)查看灰名單中包含的仍然可以調(diào)用的非 SDK 接口,灰名單以外的非 SDK 接口均不可調(diào)用。如果應(yīng)用的目標(biāo)版本為 Android Oreo 或更低,大部分的限制會(huì)被豁免,但是如果調(diào)用的非 SDK 接口不在灰名單中,那么應(yīng)用會(huì)在 logcat 中收到警告信息 (對(duì)用戶(hù)不可見(jiàn))。

請(qǐng)您在我們新發(fā)布的?Beta 2 版本上進(jìn)行測(cè)試,并使用?StrictMode?來(lái)檢測(cè)仍在使用的非 SDK 接口。請(qǐng)注意:Beta 2 版本和最終穩(wěn)定版對(duì)非 SDK 接口的使用限制基本一致。您可在文章下方留言,提出您在開(kāi)發(fā)過(guò)程中遇到的相關(guān)問(wèn)題或分享您的想法。

點(diǎn)擊查看《對(duì)于非 SDK 接口的限制》文檔了解詳細(xì)信息


?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,882評(píng)論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,208評(píng)論 3 414
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 175,746評(píng)論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 62,666評(píng)論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,477評(píng)論 6 407
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 54,960評(píng)論 1 321
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,047評(píng)論 3 440
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 42,200評(píng)論 0 288
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,726評(píng)論 1 333
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,617評(píng)論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,807評(píng)論 1 369
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,327評(píng)論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,049評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 34,425評(píng)論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 35,674評(píng)論 1 281
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,432評(píng)論 3 390
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,769評(píng)論 2 372

推薦閱讀更多精彩內(nèi)容

  • 當(dāng)我們還是孩子的時(shí)候,覺(jué)得有很多好玩的事以及有一顆好奇的心,對(duì)什么都會(huì)去靠近,好像周?chē)际峭婢撸诼L(zhǎng)大的過(guò)程中...
    陳均先生閱讀 670評(píng)論 0 3