project.json 文件里面没有 serviceClassPath 字段,导致 this.sdkClasses 为 null,触发空指针导致概率性崩溃

反馈时请提供以下信息:
–>

  • Creator 版本:2.4.11

  • 目标平台:Android TapTap的 TapPlay 直玩

你好,这边排查看到 project.json 文件里面没有 serviceClassPath 字段,导致 this.sdkClasses 为 null,触发空指针导致概率性崩溃
public void loadSDKClass() {
JSONArray jSONArray;
ArrayList arrayList = new ArrayList();
try {
jSONArray = new JSONObject(getJson(this.mainActive, “project.json”)).getJSONArray(“serviceClassPath”);
} catch (Exception e) {
e.printStackTrace();
}
// 这里应该会直接返回
if (jSONArray == null) {
return;
}

java.lang.RuntimeException: Unable to start activity ComponentInfo{org.cocos2d.yjxz/org.cocos2dx.javascript.AppActivity}: java.lang.NullPointerException: Attempt to invoke interface method ‘java.util.Iterator java.util.List.iterator()’ on a null object reference

at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3483)

at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3655)

at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:85)

at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)

at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)

at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2108)

at android.os.Handler.dispatchMessage(Handler.java:106)

at android.os.Looper.loop(Looper.java:236)

at android.app.ActivityThread.main(ActivityThread.java:7879)

at java.lang.reflect.Method.invoke(Native Method)

at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:656)

at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:967)

Caused by: java.lang.NullPointerException: Attempt to invoke interface method ‘java.util.Iterator java.util.List.iterator()’ on a null object reference

at org.cocos2dx.javascript.SDKWrapper.init(SDKWrapper.java:2)

at org.cocos2dx.javascript.AppActivity.onCreate(AppActivity.java:3)

at android.app.Activity.performCreate(Activity.java:8109)

at android.app.Activity.performCreate(Activity.java:8083)

at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1310)

at com.taptap.sandbox.client.hook.instruments.InstrumentationProxy.callActivityOnCreate(Unknown Source:11)

at com.taptap.sandbox.client.hook.instruments.a.callActivityOnCreate(Unknown Source:30)

at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3456)

(帖子被作者删除,如无标记将在 24 小时后自动删除)