I always use `json.NewDecoder(r.Body).Decode(&payload)`

The code is more succinct than reading the entire body into a buffer, and 
then unmarshalling it.
And there is only one error to check.

If I was super concerned about people sending trailing gibberish to my 
server, I could call `dec.Buffered()` to see 
if there was anything left after the json object. I generally have not seen 
people sending garbage after their requests.
And it is not clear what the correct action in these case is. I generally 
will ignore it.

On occasions that I need to consume very large json arrays in my backend, 
without consuming much memory, 
I sometimes do something like

https://play.golang.org/p/Isw_3p7mR5-

On Tuesday, 29 December 2020 at 10:51:23 UTC axel.wa...@googlemail.com 
wrote:

> There is an important semantic difference between the two, which means you 
> almost never want to use a `Decoder`: `Unmarshal` is for parsing a single 
> json document, whereas a `Decoder` is for parsing a stream of concatenated 
> documents, like so: https://play.golang.org/p/4uiNyJlNIKh. In particular, 
> this means that using a `Decoder` silently drops trailing data and might 
> not detect erronous json: https://play.golang.org/p/cuOAUnKCuEk
> So, unless you specifically know that you have a stream of concatenated 
> json documents `Decoder` is not actually doing what you want.
>
> On Tue, Dec 29, 2020 at 11:37 AM Amit Saha <amits...@gmail.com> wrote:
>
>> On Tue, Dec 29, 2020 at 11:35 AM burak serdar <bse...@computer.org> 
>> wrote:
>> >
>> > On Mon, Dec 28, 2020 at 5:22 PM Amit Saha <amits...@gmail.com> wrote:
>> > >
>> > > Hi all, let's say I am a single large JSON object that I want to
>> > > process in my HTTP server backend.
>> > >
>> > > I am trying to get my head around if there is any performance
>> > > advantage - memory or CPU to use the json.NewDecoder()/Decode()
>> > > mechanism versus the Unmarshal() function?
>> >
>> > Unmarshal uses the decoder for unmarshaling. Unless you are planning
>> > to process the JSON object piece by piece using a decoder, the two are
>> > identical in terms of performance.
>>
>> Thank you for confirming.
>>
>>
>> >
>> > >
>> > > Thanks,
>> > > Amit
>> > >
>> > > --
>> > > You received this message because you are subscribed to the Google 
>> Groups "golang-nuts" group.
>> > > To unsubscribe from this group and stop receiving emails from it, 
>> send an email to golang-nuts...@googlegroups.com.
>> > > To view this discussion on the web visit 
>> https://groups.google.com/d/msgid/golang-nuts/CANODV3%3DU2KRRkvAAEfYqRtCVtYnh2dmGreqePF8QXLo1PriSPw%40mail.gmail.com
>> .
>>
>> -- 
>> You received this message because you are subscribed to the Google Groups 
>> "golang-nuts" group.
>> To unsubscribe from this group and stop receiving emails from it, send an 
>> email to golang-nuts...@googlegroups.com.
>>
> To view this discussion on the web visit 
>> https://groups.google.com/d/msgid/golang-nuts/CANODV3%3DpXGcHzhSmaLr3f911i2CCYb0_j8CGH7zKAZXd_xTD-A%40mail.gmail.com
>> .
>>
>

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/golang-nuts/e9a6f76d-17bb-40da-84b3-2b1b8d0f3b35n%40googlegroups.com.

Reply via email to