🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Unity

Unityは、Unity Technologiesが開発・販売している、IDEを内蔵するゲームエンジンです。主にC#を用いたプログラミングでコンテンツの開発が可能です。

Q&A

解決済

1回答

1197閲覧

Unity エラーメッセージに注釈をつける

LoiJack

総合スコア2

Unity

Unityは、Unity Technologiesが開発・販売している、IDEを内蔵するゲームエンジンです。主にC#を用いたプログラミングでコンテンツの開発が可能です。

0グッド

0クリップ

投稿2021/01/23 07:43

Unityでの開発中にエラーが発生することがよくあり、
エラーメッセージ毎に解決法を表示したいと思います。

イメージとしては

####NullReferenceException: Object reference not set to an instance of an object
セットされていないオブジェクトがあります

エラーの種類を指定して注釈をつけるにはどうすればよろしいでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2021/01/23 12:25

nullに割り込めれば出来るんじゃね?みたいな感じで安易に考えてみましたがそもそもnullって発生原因は山ほどあるので、それを特定して"セットされていないオブジェクトがあります"っていう部分を特定させる条件はかなり難しいんじゃないか?って思いました。 やっぱりnullはnullなんじゃないかと。
LoiJack

2021/01/24 13:26

回答ありがとうございます。 説明が不足しており申し訳ありません。 エラーの発生原因は多くありますが、種類により代表的な原因や解決方法を 表示できればよいので原因の特定は出来なくてもよいと考えています。
guest

回答1

0

ベストアンサー

リファレンスを検索してみたところ、ILogHandlerのページに独自のログハンドラーを作って特殊な動作をさせる例が載っていました。
これを利用して追加メッセージを出せないかと思い、例をまねて下記のようなスクリプトを作ってプロジェクト内の適当な場所に入れておき...

C#

1using System; 2using System.Collections.Generic; 3using UnityEngine; 4using Object = UnityEngine.Object; 5 6public class CustomLogHandler : ILogHandler 7{ 8 // ここに捕捉したい例外と表示したい文章を登録しておく 9 private static readonly Dictionary<Type, string> Remarks = new Dictionary<Type, string> 10 { 11 {typeof(NullReferenceException), "セットされていないオブジェクトがあります"}, 12 {typeof(IndexOutOfRangeException), "インデックスが配列の境界外です"} 13 }; 14 15 // デフォルトのログハンドラーをとっておく 16 private readonly ILogHandler defaultLogHandler = Debug.unityLogger.logHandler; 17 18 // ゲームのロード時にログハンドラーをこのカスタムログハンドラーに差し替える 19 [RuntimeInitializeOnLoadMethod] 20 private static void OnLoad() 21 { 22 Debug.unityLogger.logHandler = new CustomLogHandler(); 23 } 24 25 // LogFormatはデフォルトのログハンドラーでそのまま出力する 26 public void LogFormat(LogType logType, Object context, string format, params object[] args) 27 { 28 this.defaultLogHandler.LogFormat(logType, context, format, args); 29 } 30 31 // LogExceptionはデフォルトのログハンドラーでそのまま出力したあと、 32 // もし例外に対応する文章があればLogFormatでそれを出力する 33 public void LogException(Exception exception, Object context) 34 { 35 this.defaultLogHandler.LogException(exception, context); 36 if (Remarks.TryGetValue(exception.GetType(), out var remark)) 37 { 38 this.defaultLogHandler.LogFormat(LogType.Exception, context, remark); 39 } 40 } 41}

下記のようなスクリプトで例外を発生させたところ...

C#

1using UnityEngine; 2 3public class DummyScript : MonoBehaviour 4{ 5 private void Start() 6 { 7 ((Transform)null).position = Vector3.one; 8 } 9}

下図のように、例外メッセージに続いて追加のメッセージが出力されました。

図

投稿2021/01/23 15:39

Bongo

総合スコア10811

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

LoiJack

2021/01/24 14:06

すごいです!!!! 想像していた通りの出力です。 ソースのコメントも大変分かりやすいです。 ありがとうございます☺ Bongoさんは日曜プログラマとのことですが リファレンスの見方や、問題の調査方法はどの様に学習したのでしょうか? 私はリファレンスを見ても理解できず、Qiitaなどの使用例を流用し動作確認して仕様を確認しています。
Bongo

2021/01/24 19:30

他サイトで使用例を探してみるのは大いに結構なことかと思います。すぐにいい例がヒットしないようなら、英文あるいは英単語だけで検索してみるのもいいかもしれません。Stack Overflow(https://stackoverflow.com/ )とか、本家運営のUnity Forum(https://forum.unity.com/ )とかにはマイナーな機能についての話題も投稿されていることがあって、役に立つことが多く感じます。 今回のILogHandlerはリファレンスに使用例が載っていたものの、たしかにリファレンスだと簡潔な説明しかなく物足りないことも多いですね。リファレンスだけで機能の使い方を把握できなくてもお気になさる必要はないかと思います。他サイトで使用例を探して、それの裏取りみたいな感覚でリファレンスも見てみる...といった感じでいいんじゃないでしょうか。
LoiJack

2021/01/25 02:54

ご教授ありがとうございます。 リファレンスについては見ても分からないからという理由で、敬遠していましたが 裏取りとして確認していきます。 参考サイトも確認させていただきます☺
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問