Protobuf訊息沒有實作protoreflect.ProtoMessage(ProtoReflect方法有指標接收器)
php小編新一在這裡為大家介紹一個問題:在Protobuf訊息中,我們發現沒有實作protoreflect.ProtoMessage介面的ProtoReflect方法,而該方法使用了指標接收器。這個問題可能會導致一些困惑和不便。在文章中,我們將深入探討這個問題的原因和可能的解決方案,以幫助大家更好地理解和應對這個問題。讓我們一起來了解吧!
問題內容
我有一條 protobuf 訊息導入 "google/protobuf/any.proto"
:
message mintrecord { ... google.protobuf.any data = 11; ... }
我正在嘗試使用anypb序列化data
字段內的另一個protobuf:
data, err := anypb.new(protobuf.lootcrateprize{ items: &protobuf.inventory{items: items}, roll: fmt.sprintf("%f", roll), }) if err != nil { log.println("[lootbox] err: error marshalling lootcrate prize data into mintrec", err) } else { mintrecordproto.data = data }
編譯後出現以下錯誤:
cannot use protobuf.lootcrateprize{…} (value of type protobuf.lootcrateprize) as type protoreflect.protomessage in argument to anypb.new: protobuf.lootcrateprize does not implement protoreflect.protomessage (protoreflect method has pointer receiver)
根據文檔,我在這裡沒有做任何異常的事情。我該如何解決這個問題?
這是我嘗試序列化並儲存在 data
欄位內的 protobuf:
lootcrate.proto:
syntax = "proto3"; package protobuf; option go_package = "protobuf/"; import "protobuf/inventory.proto"; import "protobuf/flowerdbservice.proto"; message LootcratePrize { Inventory items = 1; repeated NFT flowers = 2; string roll = 3; }
解決方法
sarath sadasivan pillai 是正確的。
將您的程式碼更改為:
data, err := anypb.New(&protobuf.LootcratePrize{ Items: &protobuf.Inventory{Items: items}, Roll: fmt.Sprintf("%f", roll), })
以上是Protobuf訊息沒有實作protoreflect.ProtoMessage(ProtoReflect方法有指標接收器)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

是的,H5頁面製作是前端開發的重要實現方式,涉及HTML、CSS和JavaScript等核心技術。開發者通過巧妙結合這些技術,例如使用<canvas>標籤繪製圖形或使用JavaScript控制交互行為,構建出動態且功能強大的H5頁面。

如何使用JavaScript或CSS控制瀏覽器打印設置中的頁首和頁尾在瀏覽器的打印設置中,有一個選項可以控制是否顯�...

關於inline-block元素錯位顯示的原因及解決方案在編寫網頁佈局時,我們常常會遇到一些看似奇怪的顯示問題。比...

如何實現分段器的45度曲線效果?在實現分段器的過程中,如何讓點擊左側按鈕時右側邊框變成45度曲線,而點�...

CSS自定義resize符號的方法與背景色統一在日常開發中,我們經常會遇到需要自定義用戶界面細節的情況,比如調...

實時比特幣美元價格 影響比特幣價格的因素 預測比特幣未來價格的指標 以下是 2018-2024 年比特幣價格的一些關鍵信息:
