抽象类MidiMessage有 3 个子类:MetaMessage、ShortMessage、SysexMessage。我正在听一个 MidiDevice,它发送短消息或 sysexmessages。问题是 MidiMessage 的哈希码永远不会相同。因此 MidiMessages 之间的唯一区别是数据字节数组。
我目前的解决方案是将字节存储在一个字符串中,然后检查 hashmap 是否包含该字符串:
public class Test{
private String inputKey="";
private byte[] data;
private int isShortMessage;
//...
private void setInputKey(MidiMessage msg){
inputKey="";
data=msg.getMessage();
if(msg instanceof ShortMessage){
inputKey+= ((ShortMessage) msg).getChannel();
//last byte contains the value. Value isn't needed.
isShortMessage=1;
}
else isShortMessage=0;
for(int i=0; i<msg.getLength()-isShortMessage;i++){
inputKey+= data[i];
}
}
}
但我不喜欢它,因为转换的开销(如果我总是切断最后一个字节,可以摆脱它;这几乎总是可以工作......)和字符串转换。那么,有没有更好的方法来检查 hashmap 或集合是否包含 midimesage ?