日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

消息边界处理

發布時間:2025/3/15 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 消息边界处理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、消息邊界問題


接收如下:

可以看到,由于系統默認編碼是utf-8,每個中文會被編碼為3個字節,然后我們由于這一行:

ByteBuffer buffer = ByteBuffer.allocate(4);

導致一次只能讀取4個字節,那么就會觸發兩次讀取,第一次讀到中和1/3國,第二次讀到2/3國。最終造成國亂碼。

根源就是消息邊界問題。

二、消息邊界情況

三、解決方法

  • 一種思路是固定消息長度,數據包大小一樣,服務器按預定長度讀取,缺點是浪費帶寬
  • 另一種思路是按分隔符拆分,缺點是效率低
  • TLV 格式,即 Type 類型、Length 長度、Value 數據,類型和長度已知的情況下,就可以方便獲取消息大小,分配合適的 buffer,缺點是 buffer 需要提前分配,如果內容過大,則影響 server 吞吐量
    • Http 1.1 是 TLV 格式
    • Http 2.0 是 LTV 格式
    與50位技術專家面對面20年技術見證,附贈技術全景圖

    總結

    以上是生活随笔為你收集整理的消息边界处理的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。