如何从 JavaByteBuffer中读取以 NUL 结尾的 UTF-8 字符串ByteBuffer#position()?
ByteBuffer b = /* 61 62 63 64 00 31 32 34 00 (hex) */;\nString s0 = /* read first string */;\nString s1 = /* read second string */;\n\n// `s0` will now contain \xe2\x80\x9cABCD\xe2\x80\x9d and `s1` will contain \xe2\x80\x9c124\xe2\x80\x9d.\nRun Code Online (Sandbox Code Playgroud)\n我已经尝试过使用Charsets.UTF_8.decode(b),但似乎这个函数忽略当前ByteBuffer位置并读取直到缓冲区末尾。
有没有更惯用的方法从字节缓冲区读取此类字符串,而不是寻找包含 0 的字节并将缓冲区限制为它(或将带有字符串的部分复制到单独的缓冲区中)?
\n我正在使用 nvprof 来分析某些东西(包括 CPU 工作和 GPU 工作,即我使用 nvprof 标记等),并且我得到了 nvprof 生成的二进制文件。我可以将这些导入到 NVVP(NVidia Visual Profiler;Linux 版本)中,只需稍加努力,就可以将其保存到 XML 中。
但是...... XML 不包含有关我的各种 CPU 何时执行的计时数据。它提到了他们的存在,但没有更多。此外,XML 的末尾有这个二进制 blob,可能是 Base64 编码或其他东西,位于 PDM 标记内。我不清楚那里是否有任何帮助。