【发布时间】:2016-04-13 21:22:27
【问题描述】:
我最近一直在学习Java,得出以下结论: 声明静态嵌套类型是没有意义的冗余。
我正在阅读以下问题的答案,虽然我确实理解了答案(它消除了我最初的困惑 - 类似于提问者的答案) Can a Static Nested Class be Instantiated Multiple Times? 我还得出结论,关于内部类型的静态这个词是没有意义的,例如,如果我们没有将内部类型声明为静态,我们仍然不需要实例化外部类型来创建内部类型的新对象.毕竟它是嵌套类型,而不是外部类型的成员/变量。我刚刚测试了一些代码(删除了静态代码),我的假设是正确的。
有什么我错过的吗?
这是我测试的代码(请注意,当我从 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的嵌套)。 -
您确定不是在实例中进行实例化吗?
-
有什么我遗漏的吗?:是的:代码和你如何得出这个结论的解释。
-
@Pillar 代码已更新
-
@shmosel 代码更新
标签: java