」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 調試無響應的應用程式

調試無響應的應用程式

發佈於2024-08-14
瀏覽:136

阅读其他语言:English Português 中文

有许多调试器教程可以教您如何设置行断点、记录值或计算表达式。虽然这些知识本身就为您提供了许多工具来调试应用程序,但实际场景可能会更复杂一些,并且需要更高级的方法。

在本文中,我们将学习如何在没有太多项目先验知识的情况下找到导致 UI 崩溃的代码,并即时修复损坏的代码。

问题

如果您想遵循该示例,请首先克隆此存储库:https://github.com/flounder4130/debugger-example

假设您有一个复杂的应用程序,当您执行某些操作时该应用程序会崩溃。您知道如何重现错误,但困难在于您不知道代码的哪一部分负责此功能。

Depurar Aplicaciones No Responsivas

在我们的示例应用程序中,当您单击按钮 N 时,会发生崩溃。然而,要找到负责此操作的代码并不那么容易:

Depurar Aplicaciones No Responsivas

让我们看看如何使用调试器来找到它。

方法断点

方法断点相对于行断点的优点是它们可以在类的整个层次结构中使用。这对我们的例子有什么用?

如果您查看示例项目,您将看到所有操作类均派生自 Action 接口,并具有单个方法:perform()。

Depurar Aplicaciones No Responsivas

在此接口方法上设置方法断点将在每次调用派生方法之一时挂起应用程序。要设置方法断点,请单击声明该方法的行。

启动调试会话并单击按钮 N。应用程序在 ActionImpl14 上暂停。现在我们知道这个按钮对应的代码在哪里了。

Depurar Aplicaciones No Responsivas

尽管在本文中我们的重点是查找错误,但当您想要了解某些内容在大型代码库中如何工作时,此技术也可以为您节省大量时间。

暂停应用程序

带有方法断点的方法工作得很好,但它依赖于我们了解父接口的一些假设。如果这个假设是错误的,或者我们由于其他原因不能使用这种方法怎么办?

好吧,我们甚至可以在没有断点的情况下做到这一点。单击 按钮 N,当应用程序挂起时,转到 IntelliJ IDEA。从主菜单中,选择运行 | 调试操作 | 暂停程序.

Depurar Aplicaciones No Responsivas

应用程序将挂起,允许我们检查线程和变量选项卡中线程的当前状态。这让我们了解应用程序当时正在做什么。由于它挂起,我们可以识别导致阻塞的方法并将其追溯到调用站点。

这种方法比更传统的线程转储有一些优势,我们很快就会介绍。例如,它以方便的形式为您提供有关变量的信息,并允许您控制程序的进一步执行。

提示:有关暂停程序的更多提示和技巧,请参阅无断点调试和 Debugger.godMode()

线程转储

最后,我们可以使用线程转储,这严格来说不是调试器功能。无论您是否使用调试器,它都可用。

单击按钮N。当应用程序崩溃时,转到 IntelliJ IDEA。从主菜单中,选择运行 | 调试操作 | 获取线程转储.

探索左侧的可用线程,在AWT-EventQueue中您将看到导致问题的原因。

Depurar Aplicaciones No Responsivas

线程转储的缺点是它们仅提供程序在创建时的状态快照。您不能使用线程转储来探索变量或控制程序执行。

在我们的示例中,我们不需要诉诸线程转储。但是,我仍然想提一下这种技术,因为它在其他情况下很有用,例如当您尝试调试在没有调试代理的情况下启动的应用程序时。

了解问题所在

不管调试技术如何,我们都会到达 ActionImpl14。在此类中,有人打算在单独的线程中完成工作,但将 Thread.start() 与 Thread.run() 混淆了,后者在与调用代码相同的线程中运行代码。

IntelliJ IDEA 的静态分析器甚至在设计时警告我们这一点:

Depurar Aplicaciones No Responsivas

在 UI 线程上调用执行繁重任务(或在本例中休眠很多时间)的方法,并阻止该方法直到该方法完成。这就是为什么我们在点击 按钮 N.

后一段时间内无法在 UI 中执行任何操作。

热插拔

现在我们已经找到了错误的原因,让我们纠正问题。

我们可以停止程序,重新编译代码,然后再次运行它。然而,仅仅因为做了一个小更改就重新部署整个应用程序并不总是明智的。

让我们以聪明的方式做到这一点。首先,使用建议的快速修复修复代码:

Depurar Aplicaciones No Responsivas

代码准备好后,点击运行 | 调试操作 | 重新加载更改的类。出现一个气球,确认新代码已到达虚拟机。

Depurar Aplicaciones No Responsivas

让我们回到应用程序并检查一下。单击 按钮 N 不再使应用程序崩溃。

提示:请记住 HotSwap 有其局限性。如果您对扩展的 HotSwap 功能感兴趣,那么看看 DCEVM 或 JRebel 等高级工具可能是个好主意

概括

使用我们的推理和一些调试器功能,我们能够找到导致项目中 UI 崩溃的代码。然后,我们继续修复代码,而不会浪费时间重新编译和重新分发,这在实际项目中可能会很长。

我希望您发现所描述的技术很有用。让我知道你的想法!

如果您对更多与调试和分析相关的文章感兴趣,请查看我的其他一些文章:

  • Debugger.godMode() – 使用调试器破解 JVM 应用程序
  • 调试器缓慢问题排查
  • createDirectories() 有什么问题? - CPU 分析指南
  • 无断点调试

更多精彩敬请期待!

版本聲明 本文轉載於:https://dev.to/flounder4130/depurar-aplicaciones-no-responsivas-4med?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 在UTF8 MySQL表中正確將Latin1字符轉換為UTF8的方法
    在UTF8 MySQL表中正確將Latin1字符轉換為UTF8的方法
    在UTF8表中將latin1字符轉換為utf8 ,您遇到了一個問題,其中含義的字符(例如,“jáuòiñe”)在utf8 table tabled tablesset中被extect(例如,“致電。The recommended approach to correct the data is t...
    程式設計 發佈於2025-07-17
  • 反射動態實現Go接口用於RPC方法探索
    反射動態實現Go接口用於RPC方法探索
    在GO 使用反射來實現定義RPC式方法的界面。例如,考慮一個接口,例如:鍵入myService接口{ 登錄(用戶名,密碼字符串)(sessionId int,錯誤錯誤) helloworld(sessionid int)(hi String,錯誤錯誤) } 替代方案而不是依靠反射...
    程式設計 發佈於2025-07-17
  • 可以在純CS中將多個粘性元素彼此堆疊在一起嗎?
    可以在純CS中將多個粘性元素彼此堆疊在一起嗎?
    [2这里: https://webthemez.com/demo/sticky-multi-header-scroll/index.html </main> <section> { display:grid; grid-template-...
    程式設計 發佈於2025-07-17
  • 在Python中如何創建動態變量?
    在Python中如何創建動態變量?
    在Python 中,動態創建變量的功能可以是一種強大的工具,尤其是在使用複雜的數據結構或算法時,Dynamic Variable Creation的動態變量創建。 Python提供了幾種創造性的方法來實現這一目標。 利用dictionaries 一種有效的方法是利用字典。字典允許您動態創建密鑰並...
    程式設計 發佈於2025-07-17
  • PHP SimpleXML解析帶命名空間冒號的XML方法
    PHP SimpleXML解析帶命名空間冒號的XML方法
    在php 很少,請使用該限制很大,很少有很高。例如:這種技術可確保可以通過遍歷XML樹和使用兒童()方法()方法的XML樹和切換名稱空間來訪問名稱空間內的元素。
    程式設計 發佈於2025-07-17
  • 在PHP中如何高效檢測空數組?
    在PHP中如何高效檢測空數組?
    在PHP 中檢查一個空數組可以通過各種方法在PHP中確定一個空數組。如果需要驗證任何數組元素的存在,則PHP的鬆散鍵入允許對數組本身進行直接評估:一種更嚴格的方法涉及使用count()函數: if(count(count($ playerList)=== 0){ //列表為空。 } 對...
    程式設計 發佈於2025-07-17
  • 如何使用FormData()處理多個文件上傳?
    如何使用FormData()處理多個文件上傳?
    )處理多個文件輸入時,通常需要處理多個文件上傳時,通常是必要的。 The fd.append("fileToUpload[]", files[x]); method can be used for this purpose, allowing you to send multi...
    程式設計 發佈於2025-07-17
  • 如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
    如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
    Transform Pandas DataFrame Column to DateTime FormatScenario:Data within a Pandas DataFrame often exists in various formats, including strings.使用時間數據時...
    程式設計 發佈於2025-07-17
  • 如何同步迭代並從PHP中的兩個等級陣列打印值?
    如何同步迭代並從PHP中的兩個等級陣列打印值?
    同步的迭代和打印值來自相同大小的兩個數組使用兩個數組相等大小的selectbox時,一個包含country代碼的數組,另一個包含鄉村代碼,另一個包含其相應名稱的數組,可能會因不當提供了exply for for for the uncore for the forsion for for ytry...
    程式設計 發佈於2025-07-17
  • \“(1)vs.(;;):編譯器優化是否消除了性能差異?\”
    \“(1)vs.(;;):編譯器優化是否消除了性能差異?\”
    答案: 在大多數現代編譯器中,while(1)和(1)和(;;)之間沒有性能差異。編譯器: perl: 1 輸入 - > 2 2 NextState(Main 2 -E:1)V-> 3 9 Leaveloop VK/2-> A 3 toterloop(next-> 8 last-> 9 ...
    程式設計 發佈於2025-07-17
  • 如何簡化PHP中的JSON解析以獲取多維陣列?
    如何簡化PHP中的JSON解析以獲取多維陣列?
    php 試圖在PHP中解析JSON數據的JSON可能具有挑戰性,尤其是在處理多維數組時。 To simplify the process, it's recommended to parse the JSON as an array rather than an object.To do...
    程式設計 發佈於2025-07-17
  • 如何在鼠標單擊時編程選擇DIV中的所有文本?
    如何在鼠標單擊時編程選擇DIV中的所有文本?
    在鼠標上選擇div文本單擊帶有文本內容,用戶如何使用單個鼠標單擊單擊div中的整個文本?這允許用戶輕鬆拖放所選的文本或直接複製它。 在單個鼠標上單擊的div元素中選擇文本,您可以使用以下Javascript函數: function selecttext(canduterid){ if(d...
    程式設計 發佈於2025-07-17
  • 為什麼PYTZ最初顯示出意外的時區偏移?
    為什麼PYTZ最初顯示出意外的時區偏移?
    與pytz 最初從pytz獲得特定的偏移。例如,亞洲/hong_kong最初顯示一個七個小時37分鐘的偏移: 差異源利用本地化將時區分配給日期,使用了適當的時區名稱和偏移量。但是,直接使用DateTime構造器分配時區不允許進行正確的調整。 example pytz.timezone(&#...
    程式設計 發佈於2025-07-17
  • 如何將MySQL數據庫添加到Visual Studio 2012中的數據源對話框中?
    如何將MySQL數據庫添加到Visual Studio 2012中的數據源對話框中?
    在Visual Studio 2012 儘管已安裝了MySQL Connector v.6.5.4,但無法將MySQL數據庫添加到實體框架的“ DataSource對話框”中。為了解決這一問題,至關重要的是要了解MySQL連接器v.6.5.5及以後的6.6.x版本將提供MySQL的官方Visual...
    程式設計 發佈於2025-07-17
  • 為什麼不````''{margin:0; }`始終刪除CSS中的最高邊距?
    為什麼不````''{margin:0; }`始終刪除CSS中的最高邊距?
    在CSS 問題:不正確的代碼: 全球範圍將所有餘量重置為零,如提供的代碼所建議的,可能會導致意外的副作用。解決特定的保證金問題是更建議的。 例如,在提供的示例中,將以下代碼添加到CSS中,將解決餘量問題: body H1 { 保證金頂:-40px; } 此方法更精確,避免了由全局保證金重置...
    程式設計 發佈於2025-07-17

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3