Java 空指针异常排序合并数组列表

Java 空指针异常排序合并数组列表,java,Java,我一直在试图找出如何正确打印我的方法的返回 当程序打印我的方法的返回时,我在第45行(我试图打印方法的那一行)给出了一个nullPointerException错误 *我确实尝试过将返回方法设置为静态,以便可以访问 如何初始化“answer”变量,以便在方法之外打印它? 先谢谢你 import javax.swing.JOptionPane; public class ListSortMerge { static int[]answer; public static void main(St

我一直在试图找出如何正确打印我的方法的返回

当程序打印我的方法的返回时,我在第45行(我试图打印方法的那一行)给出了一个nullPointerException错误

*我确实尝试过将返回方法设置为静态,以便可以访问

如何初始化“answer”变量,以便在方法之外打印它? 先谢谢你

import javax.swing.JOptionPane;
public class ListSortMerge {

static int[]answer;

public static void main(String[] args) {
int v1 = 0, v2 = 0;

    for(int c = 0; c <= 1; c++) {
        String values = JOptionPane.showInputDialog("How many values would you like to store in list "+(c+1)+"?");
        if (c==0) {
            v1 = Integer.parseInt(values);
        }
        else{
        v2 = Integer.parseInt(values);
        }
    }

    int[] numbers1 = new int[v1];
    int[] numbers2 = new int[v2];

    merge(numbers1,numbers2);

    int i;

    System.out.println("\nList 1 before the sort");
    System.out.println("--------------------");
    for(i = 0; i < (v1); i++) {
        System.out.println(numbers1[i]);
     }

    System.out.println("\nList 2 before the sort");
    System.out.println("--------------------");
    for(i = 0; i < (v2); i++) {
        System.out.println(numbers2[i]);
    }

    System.out.println("\nList after the sort");
    System.out.println("--------------------");
    for(i = 0; i < (v1+v2); i++) {
        System.out.println(answer[i]);
    }
}

public static int[] merge(int[] a, int[] b) {

int[] answer = new int[a.length + b.length];


for(int c = 0; c < (a.length); c++)
{
    String aVal1 = JOptionPane.showInputDialog("Input list 1 value " +(c+1));
    a[c] = Integer.parseInt(aVal1);
    }

for ( int c = 0; c < (b.length); c++){
        String aVal2 = JOptionPane.showInputDialog("Input list 2 value " +(c + 1));
        b[c] = Integer.parseInt(aVal2);
        }


int i = 0, j = 0, k = 0;

while (i < a.length && j < b.length)
{
    if (a[i] < b[j])       
        answer[k++] = a[i++];

    else        
        answer[k++] = b[j++];               
}

while (i < a.length)  
    answer[k++] = a[i++];


while (j < b.length)    
    answer[k++] = b[j++];

return answer;

}
}
import javax.swing.JOptionPane;
公共类ListSortMerge{
静态int[]答案;
公共静态void main(字符串[]args){
int v1=0,v2=0;

对于(int c=0;c您有两个不同的
answer
变量:一个是
merge
函数中的局部变量,另一个是类中的静态字段。您从不初始化第二个变量