回答編集履歴

1

具体的な解決策を記述しました

2020/05/02 03:03

投稿

Carly7766
Carly7766

スコア33

test CHANGED
@@ -1,3 +1,65 @@
1
1
  すみません。時間が経ってしまいましたが事故解決しました。
2
2
 
3
3
  クラスの依存関係がおかしいからこんなことになる訳なので素直に設計を見直しました。
4
+
5
+ 具体的には
6
+
7
+
8
+
9
+ ```c#
10
+
11
+ public class Hoge : MonoBehaviour
12
+
13
+ {
14
+
15
+ int num = 0;
16
+
17
+ public GetValue()
18
+
19
+ {
20
+
21
+ return num + 1;
22
+
23
+ }
24
+
25
+
26
+
27
+ public Die()
28
+
29
+ {
30
+
31
+ Destroy(this.gameObject);
32
+
33
+ }
34
+
35
+ }
36
+
37
+
38
+
39
+ public class Piyo : MonoBehaviour
40
+
41
+ {
42
+
43
+ [SerializeField]
44
+
45
+ private Hoge hoge;
46
+
47
+
48
+
49
+ public Awake()
50
+
51
+ {
52
+
53
+ Debug.Log(hoge.GetValue());
54
+
55
+ hoge.Die();
56
+
57
+ }
58
+
59
+ }
60
+
61
+ ```
62
+
63
+ のように関数を呼ぶ側が必要な関数を呼んだ後に`Hoge`自身を消す関数を呼ぶようにしました。
64
+
65
+ 必要に応じて`Die()`に消す前に必要な処理を書いておくといいと思います。