私は最近Javaを学び、次の結論に達しました。 静的なネストされた型を宣言することは無意味な冗長性です。私はまた、インナータイプについて、その単語が静的締結 Can a Static Nested Class be Instantiated Multiple Times? - 私は、以下の質問に答えを読んで、私は答えを理解してください(アスカーが持っていたものと類似し、それは私のinetialの混乱をクリア)しばらくしてJava静的ネストされた型セマンティック
たとえば、内部型を静的として宣言しなかった場合は、内部型の新しいオブジェクトを作成できるように外部型をインスタンス化する必要はありません。結局そのネストされた型であり、外部型のメンバ/変数ではありません。私はちょうどいくつかのコード(静的削除)をテストし、私の前提は正しかった。
紛失したことはありますか?ここ
は、私がテストしたコード(私はIGameInput内部にKeyEventタイプから静的を削除したときにすべてのものがうまく働いた、注意してください)
package FrameWork;
import java.util.List;
public interface IGameInput {
//type definitions
public static class KeyEvent {
public static final int KEY_DOWN = 0;
public static final int KEY_UP = 1;
public int type;
public int keyCode;
public char keyChar;
}
}
ある//////////////// ///////
package FrameWork.Imp;
import java.util.ArrayList;
import java.util.List;
/*
*/
public class Pool<T>
{
public interface PoolObjectFactory<T> {
public T createObject();
}
private final ArrayList<T> freeObjects;
private final PoolObjectFactory<T> factory;
private final int maxSize;
public Pool(PoolObjectFactory<T> factory, int maxSize)
{
this.factory = factory;
this.maxSize = maxSize;
this.freeObjects = new ArrayList<T>(maxSize);
}
public T newObject()
{
T object = null;
if (freeObjects.size() == 0)
{
object = factory.createObject();
}
else
{
object = freeObjects.remove(freeObjects.size() - 1);
}
return object;
}
public void free(T object)
{
if (freeObjects.size() < maxSize)
{
freeObjects.add(object);
}
}
}
////////////////////////
package FrameWork.Imp;
import java.util.ArrayList;
import java.util.List;
import android.view.View;
import android.view.View.OnKeyListener;
import FrameWork.IGameInput.KeyEvent;
import FrameWork.Imp.Pool.PoolObjectFactory;
public class KeyboardHandler implements OnKeyListener {
boolean[] pressedKeys = new boolean[128];
Pool<KeyEvent> keyEventPool;
List<KeyEvent> keyEventsBuffer = new ArrayList<KeyEvent>();
List<KeyEvent> keyEvents = new ArrayList<KeyEvent>();
public KeyboardHandler(View view) {
PoolObjectFactory<KeyEvent> factory;
factory =
new PoolObjectFactory<KeyEvent>() {
@Override
public KeyEvent createObject() {
return new KeyEvent();
}
};
keyEventPool = new Pool<KeyEvent>(factory, 100);
view.setOnKeyListener(this);
view.setFocusableInTouchMode(true);
view.requestFocus();
}
@Override
public boolean onKey(View v, int keyCode, android.view.KeyEvent event) {
if (event.getAction() == android.view.KeyEvent.ACTION_MULTIPLE) return false;
synchronized (this) {
KeyEvent keyEvent = keyEventPool.newObject();
keyEvent.keyCode = keyCode;
keyEvent.keyChar = (char) event.getUnicodeChar();
if (event.getAction() == android.view.KeyEvent.ACTION_DOWN) {
keyEvent.type = KeyEvent.KEY_DOWN;
if (keyCode > 0 && keyCode < 127) pressedKeys[keyCode] = true;
}
if (event.getAction() == android.view.KeyEvent.ACTION_UP) {
keyEvent.type = KeyEvent.KEY_UP;
if (keyCode > 0 && keyCode < 127) pressedKeys[keyCode] = false;
}
keyEventsBuffer.add(keyEvent);
}
return false;
}
}
_私の前提は正しくありましたあなたは間違ったことをしているに違いありません。囲むインスタンスなしで内部型( 'static'なしでネスト)をインスタンス化することはできません。 – Savior
インスタンス内からインスタンス化していないことは確かですか? – shmosel
*私が見逃したことはありますか?*:はい:コードとその結論に至った経緯の説明。 –