There is a prerequisite to transfer ownership: it must be proved that
no other values share ownership of the byte slice returned by 
ioutil.ReadFile.

On Saturday, September 12, 2020 at 3:42:14 AM UTC-4 tapi...@gmail.com wrote:

> Is it good to introduce owner transfer based string<->[]byte conversions?
> After the conversion, the being converted string/[]byte values mustn't be 
> used any more.
> Such as
>
> tlsCertData, _ = ioutil.ReadFile("/etc/ssl/mycert") 
> var tlsCert string = bultin.ByteSlice2String(tlsCertData)
>
> // forbid using tlsCertData any more
> _ = tlsCertData // error: tlsCertData can only used after a re-assignment.
>
> On Friday, September 11, 2020 at 3:09:57 PM UTC-4 Ian Lance Taylor wrote:
>
>> On Fri, Sep 11, 2020 at 9:45 AM Kevin Chadwick <m8il...@gmail.com> wrote:
>> >
>> > I apologise if this has already been discussed. Google didn't turn up 
>> anything
>> > directly related.
>> >
>> > If you read a file using the following that returns a byte slice.
>> >
>> > tlsCertb, err := ioutil.ReadFile("/etc/ssl/mycert")
>> > if err != nil {
>> > log.Fatal(err)
>> > }
>> > tlsCert = string(tlsCertb)
>> >
>> > Is there a way to get a string without the cast.
>> >
>> > Otherwise couldn't the language automatically return a string rather 
>> than a byte
>> > slice in these cases if the receiving var is already a string?
>> >
>> > e.g.
>> >
>> > var string tlsCert
>> > tlsCert, err = ioutil.ReadFile("/etc/ssl/mycert")
>> > if err != nil {
>> > log.Fatal(err)
>> > }
>>
>> The way Go works, ioutil.ReadFile is compiled with the io/ioutil
>> package. It can't change based on how it is called. So it is always
>> going to return []byte.
>>
>> The only way to implement what you suggest would be to add an implicit
>> conversion from []byte to string. But that seems problematic. In
>> general Go avoids implicit conversions except to interface types. And
>> a conversion to string does require a copy, so it doesn't seem like a
>> great idea to do that implicitly.
>>
>> If this happens a lot in your code, it seems easy enough to use a tiny
>> helper function.
>>
>> Ian
>>
>

-- 
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/af63dbc8-188a-46f6-aa7c-e2c44d17cf37n%40googlegroups.com.

Reply via email to