iOS

[Swift]AlertControllerでメモリリークが起きた!便利なMemory Graph

投稿日:2019年12月16日 更新日:

はじめに

こんにちは、suzukiです。この記事の結論は2点あります。AlertControllerが悪いわけではなく実装が悪かった。Memory Graphは便利!の2点です。記事の内容自体はアンチパターンとでも思っていただければ幸いです。今後の自分の調査・解析の際にMemory Graphを使用することを考えていこうというだけです。

今回の問題

今回の発症した問題の詳細は割愛させていただきますが、消したはずの画面が通知を受け取っているようなログが表示されていました。。
アプリとしては問題ない遷移と動作がおこなわれていたため気づかず開発をしていました。しかしながらある時ログに気づいてしまったため原因を調べていきました。

deinitの調査

しばらく調べた結果、念のためdeinitが呼ばれていないのではと疑い、deinitにBreakPointとprint()を記述してみたところ
見事に呼ばれていませんでした。便利ですね、deinit、、、、通知の解除を行うコードはここに書かれていたため呼ばれていないことが確定。

原因の調査

deinitが毎回呼ばれないということは何か明確な問題があるはずと思い。
コードをどんどんコメントアウトしていきました。不幸にもWKWebViewがある画面でDelegateまみれで全部疑わしく見えていました。
地道に確認したところWebViewのJavaScriptのアラートを表示するコードを削除したら、deinitが呼ばれました。
今回問題となった箇所を抜き出すと下記のようなコードとなります。

アラートの表示を行うクラス

上記を実装しているViewController

解決策

ここだけ見ると問題は単純で循環参照が起きてました。
showAlertCallBackに対して[weak self]を記述することにより循環参照が解消されます。

Memory Graphについて

問題の解決がしたところで、この話をしたところMemory Graphが便利だと聞きました。
循環参照の検知はできたりできなったりですが、インスタンスが破棄されていないことなどは一目でわかります。
問題が起きている状態で試しに動かしたところ下記のようになりました。

プロジェクトをある程度動作させた後にやってみたら、気づかなかったメモリーリークが見つかるかもしれません。
一度使ってみてください。

さいごに

XCodeで普段使っていないけど便利な機能はたくさんあるのだと再確認できました。せっかく便利なツールを使っているので、有効的に使っていけるよう、今一度XCodeの機能を再確認していきたいです。

おすすめ書籍

詳解 Swift 第5版 [改訂新版]Swift実践入門 ── 直感的な文法と安全性を兼ね備えた言語 WEB+DB PRESS plus 絶対に挫折しない iPhoneアプリ開発「超」入門 第8版 【Xcode 11 & iOS13】 完全対応

blog-page_footer_336




blog-page_footer_336




-iOS
-,

執筆者:

免責事項

このブログは、記事上部に記載のある投稿日時点の一般的な情報を提供するものであり、投資等の勧誘・法的・税務上の助言を提供するものではありません。仮想通貨の投資・損益計算は複雑であり、個々の取引状況や法律の変更によって異なる可能性があります。ブログに記載された情報は参考程度のものであり、特定の状況に基づいた行動の決定には専門家の助言を求めることをお勧めします。当ブログの情報に基づいた行動に関連して生じた損失やリスクについて、筆者は責任を負いかねます。最新の法律や税務情報を確認し、必要に応じて専門家に相談することをお勧めします。


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

CAPTCHA


関連記事

【Swift】iOS13.1、Xcode11でSceneDelegate周りを触ってみた。

1 はじめに2 SceneDelegateについて3 SceneDelegateの呼ばれる順番3.1 アプリ起動時3.2 アプリバックグラウンド3.3 アプリフォアグラウンド3.4 アプリフォアグラウ ...

iOS Chartsライブラリを使い移動平均線を描画してみる。

1 はじめに2 Chartsライブラリについて2.1 ライブラリの導入2.2 描画の準備3 折れ線グラフを描画する3.1 LineChartViewの設定3.2 LineChart用のデータ作成3.3 ...

iOS13で発生するUICollectionviewのカクつきを解消する

iOS13でCollectionViewの動作が少し変わりました。 Cellの入れ替え時にデータの更新を行う際にはどのように作成すれば良いか、関係のあるデリゲートを含め説明させていただいております。 おまけとして、Xcode11.3対応を行った際に対応した内容を簡単にですが記述しております。Xcode11対応をされる方の参考になればと思います。

UIWebViewからWKWebViewへの移行

1 はじめに2 ターゲットとなるUIWebViewで行なっていること3 URLへのアクセス4 ローカルHTMLの読み込み5 ページを戻す、進める6 ページの読み込み開始時や終了時に処理を行う(dele ...

swift

Swiftの「UIActivityViewController」でTwitterにだけハッシュタグをつけたい!

1 はじめに2 実装2.1 まずはやってみよう2.2 Twitter連携時のみにハッシュタグをつけたい3 さいごに はじめに こんにちわ、nukkyです。 今回はSNSやメール連携したいときに便利な ...

フォロー

blog-page_side_responsive

2019年12月
1234567
891011121314
15161718192021
22232425262728
293031  

アプリ情報

私たちは無料アプリもリリースしています、ぜひご覧ください。 下記のアイコンから無料でダウンロードできます。