0

抽象类MidiMessage有 3 个子类:MetaMessage、ShortMessageSysexMessage。我正在听一个 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 ?

4

1 回答 1

0

我将使用:

Arrays.hashCode(byte[] a)

于 2013-10-21T18:21:08.440 回答