Потрібно кваліфікувати розподіл із вкладеним екземпляром типу GeoLocation


109

Я отримую цю помилку як-

Немає доступного примірника типу GeoLocation, що вкладається. Потрібно кваліфікувати розподіл із вкладеним екземпляром типу GeoLocation (наприклад ,xnew A (), де x - екземпляр GeoLocation). Ця помилка надходить у новій ThreadTask (i) . Я не знаю, чому це відбувається. Будь-які пропозиції будуть вдячні.

public class GeoLocation {
    public static void main(String[] args) throws InterruptedException {
        int size = 10;

        // create thread pool with given size
        ExecutorService service = Executors.newFixedThreadPool(size); 

        // queue some tasks
        for(int i = 0; i < 3 * size; i++) {
            service.submit(new ThreadTask(i));
        }

        // wait for termination        
        service.shutdown();
        service.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS); 
    }

    class ThreadTask implements Runnable {
        private int id;

        public ThreadTask(int id) {
            this.id = id;
        }

        public void run() {
            System.out.println("I am task " + id);
        }
    }

}

2
Дивіться цей відповідь: stackoverflow.com/questions/633585 / ...
hmjd

Відповіді:


150

Привіт, я знайшов рішення для цього ;-)

Ця помилка трапляється тому, що ви намагаєтесь створити екземпляр внутрішнього класу service.submit(new ThreadTask(i)); без створення екземпляра основного класу ..

Щоб вирішити цю проблему, спочатку створіть екземпляр основного класу:

GeoLocation outer = new GeoLocation();

Потім створіть екземпляр класу, який ви мали намір викликати, таким чином:

service.submit(outer.new ThreadTask(i));

Сподіваюся, це вирішить вашу проблему ;-)


101

Ще одним варіантом, який я віддаю перевагу, було б встановити внутрішній клас статичним.

public static class ThreadTask implements Runnable { ... }

Працювали чудово і для мене. Я думаю, що це має бути кращим рішенням, оскільки 1) Це найпростіший і 2) Основний метод - статичний.
Алан

15

Складіть клас вбудованих static.

public class OuterClass {

    static class InnerClass {
    }

    public InnerClass instance = new OuterClass.InnerClass();
}

Тоді ви можете створити внутрішній клас таким чином:

new OuterClass.InnerClass();

3

Зробіть цю структуру:

ФАЙЛ GeoLocation.java

public class GeoLocation {

    public static void main(String[] args) throws InterruptedException {

        int size = 10;

        // create thread pool with given size
        ExecutorService service = Executors.newFixedThreadPool(size); 

        // queue some tasks
        for(int i = 0; i < 3 * size; i++) {
            service.submit(new ThreadTask(i));
        }

        // wait for termination        
        service.shutdown();
        service.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS); 
    }

}

Файл ThreadTask.java

public class ThreadTask implements Runnable {
    private int id;

    public ThreadTask(int id) {
        this.id = id;
    }

    public void run() {
        System.out.println("I am task " + id);
    }
}

4
Ласкаво просимо на ТАК, ось, це хороша практика пояснити, чому слід використовувати своє рішення, а не тільки як. Це зробить вашу відповідь більш цінною та допоможе подальшому читачеві краще зрозуміти, як ви це робите. Я також пропоную вам ознайомитися з нашими поширеними питаннями: stackoverflow.com/faq .
ForceMagic

2

Вам потрібно створити екземпляр батьківського класу, щоб створити екземпляри внутрішніх класів. Ось приклад:

package RandomTests;

public class FinalConstructorTest {


    public static void main (String [] arg){
        FinalConstructorTest fct= new FinalConstructorTest();
        InnerClass1 f1= fct.new InnerClass1(99);
        InnerClass2 f2= fct.new InnerClass2();
    }

    class InnerClass1{
        private final int num2;

        protected InnerClass1(int num){
            num2= num;
            System.out.println("num2= "+ num2);
        }
    }
    class InnerClass2{
        //private static final int x; //Doesn't work
        private final int y; 

        {
            y= 5;
            System.out.println("y= "+ y);
        }
    }
}

1

Це також може статися, якщо ви отримуєте доступ до нестатичних членів зі статичних методів або аналогічно. Далі є два різних аспекти, один, який викликає помилку, та інший вирішений фрагмент коду. справа лише в тому, щоб зробити інший як клас "статичним"

package Stack;

import java.util.Stack;
import java.util.*;

public class StackArrList {

    public static void main(String[] args) {


        Scanner in = new Scanner(System.in);

        Stack S = new Stack();
        System.out.println("Enter some integers and keep 0 at last:\n");
        int n = in.nextInt();

        while (n != 0) {
            S.push(n);
            n = in.nextInt();
        }
        System.out.println("Numbers in reverse order:\n");

        while (!S.empty()) {

            System.out.printf("%d", S.pop());
            System.out.println("\n");

        }

    }

    public class Stack {
        final static int MaxStack = 100;
        final static int Value = -999999;
        int top = -1;
        int[] ST = new int[MaxStack];

        public boolean empty() {
            return top == -1;
        }

        public int pop() {

            if (this.empty()) {
                return Value;
            }
            int hold = ST[top];
            top--;
            return hold;
        }

        public void push(int n) {
            if (top == MaxStack - 1) {
                System.out.println("\n Stack Overflow\n");
                System.exit(1);
            }
            top++;
            ST[top] = n;

        }

    }

}

Це призводить до помилки. Немає доступного примірника типу StackArrList, що додається. Потрібно кваліфікувати розподіл із вкладеним екземпляром типу StackArrList (egxnew A (), де x - екземпляр StackArrList). і не дозволить зробити екземпляр класу Stack

Коли ви зробите клас Stack до статичного класу Stack буде працювати нормально, і помилок не буде.

package Stack;

import java.util.Stack;
import java.util.*;

public class StackArrList {

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);

        Stack S = new Stack();
        System.out.println("Enter some integers and keep 0 at last:\n");
        int n = in.nextInt();

        while (n != 0) {
            S.push(n);
            n = in.nextInt();
        }
        System.out.println("Numbers in reverse order:\n");

        while (!S.empty()) {

            System.out.printf("%d", S.pop());
            System.out.println("\n");

        }

    }

    static class Stack {
        final static int MaxStack = 100;
        final static int Value = -999999;
        int top = -1;
        int[] ST = new int[MaxStack];

        public boolean empty() {
            return top == -1;
        }

        public int pop() {

            if (this.empty()) {
                return Value;
            }
            int hold = ST[top];
            top--;
            return hold;
        }

        public void push(int n) {
            if (top == MaxStack - 1) {
                System.out.println("\n Stack Overflow\n");
                System.exit(1);
            }
            top++;
            ST[top] = n;

        }

    }

}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.