Go Concepts - The Type System: Difference between revisions
(→Slice) |
(→Maps) |
||
Line 36: | Line 36: | ||
==Maps== | ==Maps== | ||
==struct== | |||
==interface== | |||
=Conversion Between Types= | =Conversion Between Types= |
Revision as of 22:22, 17 March 2016
Internal
Overview
Go is statically typed. Go designers tried to alleviate some of the "heaviness" associated with statically typed languages and made it "feel" like a dynamic language. For example Go uses local type inference, which eliminates the need to specify the type unnecessarily in program, the compiler figures it out.
Go is strongly typed meaning that yes cannot be unsafely coerced into other types they're not, or at least without programmer giving explicit permission. In JavaScript, for example, implicit conversion is done based on complicated rules that are not always easy to remember.
For more details on typing, see static typing vs. dynamic typing and strong typing vs. loose typing.
Value and Reference Types
Zero Value
Zero value for a specific type: 0 for ints, 0.0 for floats, "" for string, false for Booleans and nil for pointers. For reference types, their underlying data structures are initialized to their zero values.
Number
String
String Operators and Functions
Built-in Types
Arrays
Slice
A slice is a reference type that implements a dynamic array.
Slice built-in functions append(), copy().
TODO Deep difference between slice and array (memory model, etc.)