On Saturday, August 6, 2016 at 6:04:00 PM UTC+8, atd...@gmail.com wrote:
>
>
>
> On Saturday, August 6, 2016 at 11:53:42 AM UTC+2, T L wrote:
>>
>>
>>
>> On Saturday, August 6, 2016 at 5:45:50 PM UTC+8, atd...@gmail.com wrote:
>>>
>>> No, I'm saying that the current implementation is two pointers.
>>> The value is addressed by the second pointer. So you cannot really put a 
>>> const in an interface. (thought experiment)
>>>
>>> Of course, in the specific case of boxing a value type, that could work. 
>>> If you accept that the *typ never changes throughout the program.
>>>
>>
>> for constant intrfaces, the *typ property is not needed. Calling of their 
>> methods will confirmed at compile time.
>>
>  
> You need it, the interface cannot be of any type, it would need to be 
> initialized with a value of a given type for method dispatch.
> The only thing is that the method dispatch would be fixed. (again a 
> thought experiment :) 
>

> That's similar to sync.Value ( https://golang.org/pkg/sync/atomic/#Value)
>  
>
>>  
>>
>>>
>>> The question is, why a special case, what would you use it for? 
>>> sync.Pools ?
>>>
>>> If it's just for error variables to be constants, maybe it is not worth 
>>> it. What problem does it solve ?
>>>
>>
>> for safety.
>>
>
> What is trhe safety issue? Do you have an example at hand? 
>

If you carelessly change the value of a global variable in std lib, some 
hard found bugs will be created.
 

>  
>>
>>>
>>> On Saturday, August 6, 2016 at 11:11:24 AM UTC+2, T L wrote:
>>>>
>>>>
>>>>
>>>> On Saturday, August 6, 2016 at 4:06:07 PM UTC+8, atd...@gmail.com 
>>>> wrote:
>>>>>
>>>>> Possibily, if you freeze the type of things that can be boxed by the 
>>>>> interface. But what would it be useful for ?
>>>>> That would just mean that an interface is constant. Not even that the 
>>>>> value it wraps can't be changed (because with the current implementation, 
>>>>> the values an interface wraps need to be addressable).
>>>>>
>>>>
>>>> you mean a value should be addressable to let an interface wraps wrap 
>>>> it?
>>>> Not true, "_ = interface{}(1)" is valid in current implementation.
>>>>  
>>>>
>>>>>
>>>>>
>>>>>
>>>>> On Saturday, August 6, 2016 at 9:53:26 AM UTC+2, T L wrote:
>>>>>>
>>>>>> Is it possible to make an interface constant if its concrete value 
>>>>>> type is bool/number/string?
>>>>>>
>>>>>> On Saturday, August 6, 2016 at 3:48:17 AM UTC+8, Ian Lance Taylor 
>>>>>> wrote:
>>>>>>>
>>>>>>> On Fri, Aug 5, 2016 at 11:21 AM, T L <tapi...@gmail.com> wrote: 
>>>>>>> > 
>>>>>>> > For an interface value, its internal values will never change. 
>>>>>>> > Are there any problems if golang supports constant interface 
>>>>>>> values? 
>>>>>>>
>>>>>>> Pedantically, in Go, constants are untyped by default.  It doesn't 
>>>>>>> make sense to speak of an untyped interface value.  I would describe 
>>>>>>> what you are asking for as an immutable variable.  I've often 
>>>>>>> thought 
>>>>>>> that immutable variables would be useful in Go, but since they have 
>>>>>>> to 
>>>>>>> be initialized it's not that simple.  For example, io.EOF is 
>>>>>>> initialized using a function call.  That means that it can't 
>>>>>>> actually 
>>>>>>> be in read-only memory, and of course it's possible to take it's 
>>>>>>> address.  How do we prevent it from being changed, without 
>>>>>>> introducing 
>>>>>>> an immutable qualifier into the type system?  It's a complex problem 
>>>>>>> for which I have no solution.  And the benefits of an immutable 
>>>>>>> variable aren't all that high. 
>>>>>>>
>>>>>>> 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.
For more options, visit https://groups.google.com/d/optout.

Reply via email to