我正在从服务器接收UDP数据包(确切地说:打开声音控制数据包)。我将这些数据包存储在ByteArray中。
我想将此ByteArray转换为String,以便我可以利用收到的数据。我尝试了很多转换,但每次我都有不可读的字符。
以下是代码:
| server peerAddr |
server := SocketAccessor newUDPserverAtPort: 3333.
peerAddr := IPSocketAddress new.
buffer := ByteArray new: 1024.
[ server readWait.
server receiveFrom: peerAddr buffer: buffer.
Transcript show: (buffer asString) ; cr ; flush. ] repeat.
我也尝试过以下转换,但徒劳无功:
buffer asByteString.
buffer asStringEncoding:#UTF8.
buffer asStringEncoding:#UTF16.
buffer asString.
buffer asBase64String.
buffer asFourByteString
buffer withEncoding: #ASCII
这是字符串输出:
任何帮助?
其他信息:收到的数据是打开的声音控制数据,所以它有一个特定的格式,这就是为什么它像这样,我需要解析整数,浮点数,字符串,白色特定的字节数组索引。是否有人重新提供了提供这些可能性的包装?
提前谢谢。答案 0 :(得分:3)
如果要从字节数组中读取数据,请使用UninterpretedBytes类。
你可以这样做:
ubytes:= UninterpretedBytes from:aByteArray。 ubytes doubleAt:5。
像这样的东西。 您还可以使用未解释的字节从字节中读取字符串。答案 1 :(得分:3)
将字节转换为字符串的正确方法肯定是应用正确的字符编码。以下
(65 to: 75) asByteArray asStringEncoding: #UTF8
应该产生
'ABCDEFGHIJK'
使用#asStringEncoding:是正确的方法。然而,看着你的屏幕截图,你接收的字节似乎不是直字符串。可能有一些二进制数据包格式需要首先拆分,然后只解码为字符串那些你知道实际上是utf8编码的部分(或者编码是什么)。
答案 2 :(得分:2)
你可能可以为Squeak的OSC包借用很多代码:http://opensoundcontrol.org/implementation/squeak-osc