将 Get 方法与一个 class 而不是另一个一起使用时出现 NullPointErexception
NullPointException when using GetMethods with one class but not another
我正在尝试创建一个脚本来更改当前的麦克风焦点,但我目前对脚本的行为感到困惑。我有两个部分,我从两个 classes 中获取所有方法(分为两个 catch 进程)。使用 "AudioManager" 时,我可以通过使用...
getMethods()
方法[]方法1 = audioManager.getClass().getMethods();
-或-
方法[]方法1 = AudioManager.class.getMethods();
它们都列出了分解成字符串后的整个方法数组。
但是,如果我 运行 针对 "AudioDeviceInfo" 使用相同的相同过程并使用完全相同的选项,其中一个将失败。
方法[]方法2 = audioDeviceInfo.getClass().getMethods(); (失败)
-或-
方法[]方法2 = AudioDeviceInfo.class.getMethods(); (成功)
package com.example.myfirstapp;
import android.content.Context;
import android.media.AudioDeviceInfo;
import android.media.AudioManager;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.Switch;
import android.widget.TextView;
import androidx.appcompat.app.AppCompatActivity;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class MainActivity extends AppCompatActivity {
private Switch sw1;
TextView slvtxt;
Button btnGet;
Context context;
AudioManager audioManager;
AudioDeviceInfo audioDeviceInfo;
private static List<String> getFieldNamesOne(Method[] methods1) {
List<String> fieldNames1 = new ArrayList<>();
for (Method method1 : methods1)
fieldNames1.add(method1.getName());
return fieldNames1;
}
private static List<String> getFieldNamesTwo(Method[] methods2) {
List<String> fieldNames2 = new ArrayList<>();
for (Method method2 : methods2)
fieldNames2.add(method2.getName());
return fieldNames2;
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
context = getApplicationContext();
audioManager = ((AudioManager)getSystemService(Context.AUDIO_SERVICE));
setContentView(R.layout.activity_main);
slvtxt = findViewById(R.id.slaveText);
sw1 = findViewById(R.id.switch1);
btnGet = findViewById(R.id.getBtn);
btnGet.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
try {
Method[] methods1 = audioManager.getClass().getMethods();
//Method[] methods1 = AudioManager.class.getMethods();
List<String> actualFieldNames1 = getFieldNamesOne(methods1);
Log.d("tag","FOUND METHOD RETURN: " + Arrays.toString(actualFieldNames1.toArray()));
Method methodVar1 = audioManager.getClass().getMethod("setWiredDeviceConnectionState", Integer.TYPE, Integer.TYPE, String.class, String.class);
Log.d("tag","Method: " + methodVar1.getName());
methodVar1.setAccessible(true);
} catch (NoSuchMethodException e) {
e.printStackTrace();
Log.d("tag","No Such Method : WiredDevice");
} catch (NullPointerException e) {
e.printStackTrace();
Log.d("tag","Null Point : WiredDevice");
}
try {
Method[] methods2 = audioDeviceInfo.getClass().getMethods();
List<String> actualFieldNames2 = getFieldNamesTwo(methods2);
Log.d("tag","FOUND METHOD RETURN: " + Arrays.toString(actualFieldNames2.toArray()));
} catch (NullPointerException e) {
e.printStackTrace();
Log.d("tag","Null Point : GetAddress");
}
}
});
}
}
LogCat错误
W/System.err: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.Class java.lang.Object.getClass()' on a null object reference
at com.example.myfirstapp.MainActivity.onClick(MainActivity.java:91)
at android.view.View.performClick(View.java:5610)
at android.view.View$PerformClick.run(View.java:22265)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6077)
at java.lang.reflect.Method.invoke(Native Method)
W/System.err: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:866)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:756)
D/tag: Null Point : GetAddress
Process 4630 terminated.
我希望每组的两个版本都会有相同的结果。我想使用的代码的其他项目遵循使用变量 audioManager 和 audioDeviceInfo 的格式,而不是 getMethod 的核心 class 类型,我想确保我没有在管道中进一步做一些完全错误的事情深入挖掘。
您需要先初始化您的变量 audioDeviceInfo
,然后才能使用它。
可能您需要类似以下行的内容:
audioDeviceInfo = audioManager.getDevices(AudioManager.GET_DEVICES_OUTPUTS);
为什么它与 audioManager
一起使用?
因为你给它赋值:
audioManager = ((AudioManager)getSystemService(Context.AUDIO_SERVICE));
为什么其他情况有效?
在其他两种情况下,您使用的是永远不会为空的 class 本身:
Method[] methods1 = AudioManager.class.getMethods();
Method[] methods2 = AudioDeviceInfo.class.getMethods();
请看一下这个答案:
我正在尝试创建一个脚本来更改当前的麦克风焦点,但我目前对脚本的行为感到困惑。我有两个部分,我从两个 classes 中获取所有方法(分为两个 catch 进程)。使用 "AudioManager" 时,我可以通过使用...
getMethods()方法[]方法1 = audioManager.getClass().getMethods();
-或-
方法[]方法1 = AudioManager.class.getMethods();
它们都列出了分解成字符串后的整个方法数组。
但是,如果我 运行 针对 "AudioDeviceInfo" 使用相同的相同过程并使用完全相同的选项,其中一个将失败。
方法[]方法2 = audioDeviceInfo.getClass().getMethods(); (失败)
-或-
方法[]方法2 = AudioDeviceInfo.class.getMethods(); (成功)
package com.example.myfirstapp;
import android.content.Context;
import android.media.AudioDeviceInfo;
import android.media.AudioManager;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.Switch;
import android.widget.TextView;
import androidx.appcompat.app.AppCompatActivity;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class MainActivity extends AppCompatActivity {
private Switch sw1;
TextView slvtxt;
Button btnGet;
Context context;
AudioManager audioManager;
AudioDeviceInfo audioDeviceInfo;
private static List<String> getFieldNamesOne(Method[] methods1) {
List<String> fieldNames1 = new ArrayList<>();
for (Method method1 : methods1)
fieldNames1.add(method1.getName());
return fieldNames1;
}
private static List<String> getFieldNamesTwo(Method[] methods2) {
List<String> fieldNames2 = new ArrayList<>();
for (Method method2 : methods2)
fieldNames2.add(method2.getName());
return fieldNames2;
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
context = getApplicationContext();
audioManager = ((AudioManager)getSystemService(Context.AUDIO_SERVICE));
setContentView(R.layout.activity_main);
slvtxt = findViewById(R.id.slaveText);
sw1 = findViewById(R.id.switch1);
btnGet = findViewById(R.id.getBtn);
btnGet.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
try {
Method[] methods1 = audioManager.getClass().getMethods();
//Method[] methods1 = AudioManager.class.getMethods();
List<String> actualFieldNames1 = getFieldNamesOne(methods1);
Log.d("tag","FOUND METHOD RETURN: " + Arrays.toString(actualFieldNames1.toArray()));
Method methodVar1 = audioManager.getClass().getMethod("setWiredDeviceConnectionState", Integer.TYPE, Integer.TYPE, String.class, String.class);
Log.d("tag","Method: " + methodVar1.getName());
methodVar1.setAccessible(true);
} catch (NoSuchMethodException e) {
e.printStackTrace();
Log.d("tag","No Such Method : WiredDevice");
} catch (NullPointerException e) {
e.printStackTrace();
Log.d("tag","Null Point : WiredDevice");
}
try {
Method[] methods2 = audioDeviceInfo.getClass().getMethods();
List<String> actualFieldNames2 = getFieldNamesTwo(methods2);
Log.d("tag","FOUND METHOD RETURN: " + Arrays.toString(actualFieldNames2.toArray()));
} catch (NullPointerException e) {
e.printStackTrace();
Log.d("tag","Null Point : GetAddress");
}
}
});
}
}
LogCat错误
W/System.err: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.Class java.lang.Object.getClass()' on a null object reference
at com.example.myfirstapp.MainActivity.onClick(MainActivity.java:91)
at android.view.View.performClick(View.java:5610)
at android.view.View$PerformClick.run(View.java:22265)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6077)
at java.lang.reflect.Method.invoke(Native Method)
W/System.err: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:866)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:756)
D/tag: Null Point : GetAddress
Process 4630 terminated.
我希望每组的两个版本都会有相同的结果。我想使用的代码的其他项目遵循使用变量 audioManager 和 audioDeviceInfo 的格式,而不是 getMethod 的核心 class 类型,我想确保我没有在管道中进一步做一些完全错误的事情深入挖掘。
您需要先初始化您的变量 audioDeviceInfo
,然后才能使用它。
可能您需要类似以下行的内容:
audioDeviceInfo = audioManager.getDevices(AudioManager.GET_DEVICES_OUTPUTS);
为什么它与 audioManager
一起使用?
因为你给它赋值:
audioManager = ((AudioManager)getSystemService(Context.AUDIO_SERVICE));
为什么其他情况有效?
在其他两种情况下,您使用的是永远不会为空的 class 本身:
Method[] methods1 = AudioManager.class.getMethods();
Method[] methods2 = AudioDeviceInfo.class.getMethods();
请看一下这个答案: