崩潰報告
TIP
如果你在尋找崩潰原因時遇到任何困難,你可以在 Fabric Discord 的 #player-support
或 #server-admin-support
頻道中尋求幫助。
崩潰報告是排解遊戲或伺服器問題的非常重要的一部分。 它們包含了關於崩潰的大量資訊,可以幫助你找到崩潰的原因。
尋找崩潰報告
崩潰報告儲存在遊戲目錄中的 crash-reports 資料夾中。 如果您正在使用伺服器,則它們儲存在伺服器目錄中的 crash-reports
資料夾中。 如果您正在使用伺服器,則它們儲存在伺服器目錄中的 crash-reports
資料夾中。
對於第三方啟動器,你應參考它們的文件以找到崩潰報告的位置。
崩潰報告可以在以下位置找到:
%appdata%\.minecraft\crash-reports
~/Library/Application Support/minecraft/crash-reports
~/.minecraft/crash-reports
閱讀崩潰報告
崩潰報告非常長,且讀起來可能會很困難。 然而,它們包含了許多關於崩潰的資訊,可以幫助你找出崩潰的原因。
在本指南中,我們將使用這個崩潰報告作為範例。
崩潰報告部分
崩潰報告由幾個部分組成,每個部分都使用標題分隔:
---- Minecraft Crash Report ----
,報告的摘要。 這個部分包含導致崩潰的主要錯誤、發生時間以及相關的堆疊追蹤。 這是崩潰報告中最重要的部分,因為堆疊追蹤通常包含導致崩潰的模組的參考。 這個部分包含導致崩潰的主要錯誤、發生時間以及相關的堆疊追蹤。 這是崩潰報告中最重要的部分,因為堆疊追蹤通常包含導致崩潰的模組的參考。-- Last Reload --
,這個部分除非崩潰發生在資源重新載入期間(F3+T),否則沒有什麼用。 這個部分將包含上次重新載入的時間以及重新載入過程中發生的任何錯誤的相關堆疊追踪。 這些錯誤通常是由資源包引起的,除非它們對遊戲造成問題,否則可以忽略。-- System Details --
,這個部分包含有關你系統的資訊,例如作業系統、Java 版本和配置給遊戲的記憶體。 這個部分對於確定你是否使用正確的 Java 版本以及是否為遊戲配置足夠的記憶體很有用。 這個部分對於確定你是否使用正確的 Java 版本以及是否為遊戲配置足夠的記憶體很有用。- 在這一部分,Fabric 將包括一個自訂行,其中說明了
Fabric Mods:
,後面跟著您安裝的所有模組的清單。 這個部分對於確定模組之間是否可能發生衝突很有用。
- 在這一部分,Fabric 將包括一個自訂行,其中說明了
分解崩潰報告
現在我們知道崩潰報告的每個部分是什麼,我們可以開始分解崩潰報告,找出崩潰的原因。
使用上面連結的範例,我們可以分析崩潰報告,找出崩潰的原因,包括導致崩潰的模組。
崩潰報告是排解遊戲或伺服器問題的非常重要的一部分。 它們包含了關於崩潰的大量資訊,可以幫助你找到崩潰的原因。 ---- Minecraft Crash Report ----
部分中的堆棧跟踪在這種情況下最重要,因為它包含導致崩潰的主要錯誤。 在這個案例中,錯誤是 java.lang.NullPointerException: Cannot invoke "net.minecraft.class_2248.method_9539()" because "net.minecraft.class_2248.field_10540" is null
。
由於堆疊追蹤中提到了大量的模組,要指出責任者可能有些困難,但首先要做的是尋找導致崩潰的模組。
at snownee.snow.block.ShapeCaches.get(ShapeCaches.java:51)
at snownee.snow.block.SnowWallBlock.method_9549(SnowWallBlock.java:26)
...
at me.jellysquid.mods.sodium.client.render.chunk.compile.pipeline.BlockOcclusionCache.shouldDrawSide(BlockOcclusionCache.java:52)
at link.infra.indium.renderer.render.TerrainBlockRenderInfo.shouldDrawFaceInner(TerrainBlockRenderInfo.java:31)
在這種情況下,導致崩潰的模組是 snownee
,因為它是堆疊追蹤中首先提到的模組。
然而,由於堆疊追蹤中提到了大量的模組,這可能表示模組之間存在一些相容性問題,並且導致崩潰的模組可能不是真正的問題所在。 在這種情況下,最好將崩潰報告提交給模組作者,並讓他們調查崩潰。
Mixin 崩潰
INFO
Mixin 是一種讓模組無需修改遊戲原始碼即可修改遊戲的方法。 它們被許多模組使用,是模組開發人員非常強大的工具。 它們被許多模組使用,是模組開發人員非常強大的工具。
當 mixin 崩潰時,堆疊追蹤通常會提到 mixin 和被修改的類。
方法 mixin 將在堆疊追蹤中包含 modid$handlerName
,其中 modid
是模組的 ID,handlerName
是 mixin 處理程序的名稱。
... net.minecraft.class_2248.method_3821$$$modid$handlerName() ...
你可以使用這個資訊找到導致崩潰的模組,並將崩潰報告提交給模組作者。
處理崩潰報告
處理崩潰報告的最佳方法是將它上傳至文字分享網站,並將連結分享給模組作者、錯誤追蹤器或透過某種形式的交流(Discord 等)。
這將使模組作者能夠調查崩潰,可能重現它並解決導致崩潰的問題。
常見的文字分享網站為: