Data types specify the type of data that a valid Go variable can hold. In Go language, the type is divided into four categories which are as follows:
- Basic type: Numbers, strings, and booleans come under this category.
- Aggregate type: Array and structs come under this category.
- Reference type: Pointers, slices, maps, functions, and channels come under this category.
- Interface type
Here, we will discuss Basic Data Types in the Go language. The Basic Data Types are further categorized into three subcategories which are:Â
- Numbers
- Booleans
- Strings
Numbers
In Go language, numbers are divided into three sub-categories that are:
- Integers: In Go language, both signed and unsigned integers are available in four different sizes as shown in the below table. The signed int is represented by int and the unsigned integer is represented by uint.
- Possible arithmetic operations : Addition, subtraction, multiplication, division, remainder
Data Type |
Description |
---|---|
int8 | 8-bit signed integer |
int16 | 16-bit signed integer |
int32 | 32-bit signed integer |
int64 | 64-bit signed integer |
uint8 | 8-bit unsigned integer |
uint16 | 16-bit unsigned integer |
uint32 | 32-bit unsigned integer |
uint64 | 64-bit unsigned integer |
int | Both int and uint contain same size, either 32 or 64 bit. |
uint | Both int and uint contain same size, either 32 or 64 bit. |
rune | It is a synonym of int32 and also represent Unicode code points. |
byte | It is a synonym of uint8. |
uintptr | It is an unsigned integer type. Its width is not defined, but its can hold all the bits of a pointer value. |
Example:
Go
// Go program to illustrate // the use of integers package main import "fmt"         func main() {          // Using 8-bit unsigned int     var X uint8 = 225     fmt.Println(X, X- 3 )          // Using 16-bit signed int     var Y int16 = 32767     fmt.Println(Y+ 2 , Y- 2 ) } |
Output:Â
225 222 -32767 32765
Example of arithmetic operations :
Go
// Possible arithmetic operations for intigers // Author : Chhanda Saha Â
package main Â
import "fmt" Â
func main() { Â
    var x int16 = 170     var y int16 = 83     //Addition     fmt.Printf( " addition : %d + %d = %d\n " , x, y, x+y)     //Subtraction     fmt.Printf( "subtraction : %d - %d = %d\n" , x, y, x-y)     //Multiplication     fmt.Printf( " multiplication : %d * %d = %d\n" , x, y, x*y)     //Division     fmt.Printf( " division : %d / %d = %d\n" , x, y, x/y)     //Modulus     fmt.Printf( " remainder : %d %% %d = %d\n" , x, y, x%y) } |
Output:
addition : 170 + 83 = 253 subtraction : 170 - 83 = 87 multiplication : 170 * 83 = 14110 division : 170 / 83 = 2 remainder : 170 % 83 = 4
- Floating-Point Numbers: In Go language, floating-point numbers are divided into two categories as shown in the below table.
- Possible arithmetic operations : Addition, subtraction, multiplication, division.
- Three literal styles are available :
- decimal (3.15)
- exponential ( 12e18 or 3E10)
- mixed (13.16e12)
Data Type |
Description |
---|---|
float32 | 32-bit IEEE 754 floating-point number |
float64 | 64-bit IEEE 754 floating-point number |
Example:
Go
// Go program to illustrate // the use of floating-point // numbers package main import "fmt"         func main() {     a := 20.45     b := 34.89          // Subtraction of two     // floating-point number     c := b-a          // Display the result     fmt.Printf( "Result is: %f" , c)          // Display the type of c variable     fmt.Printf( "\nThe type of c is : %T" , c) } |
Output:Â
Result is: 14.440000 The type of c is : float64
Example of arithmetic operations for floating point numbers :
Go
// Possible arithmetic operations for float numbers // Author : Chhanda Saha package main Â
import "fmt" Â
func main() {     var x float32 = 5.00     var y float32 = 2.25     //Addition     fmt.Printf( "addition : %g + %g = %g\n " , x, y, x+y)     //Subtraction     fmt.Printf( "subtraction : %g - %g = %g\n" , x, y, x-y)     //Multiplication     fmt.Printf( "multiplication : %g * %g = %g\n" , x, y, x*y)     //Division     fmt.Printf( "division : %g / %g = %g\n" , x, y, x/y) Â
} |
Output:
addition : 5 + 2.25 = 7.25 subtraction : 5 - 2.25 = 2.75 multiplication : 5 * 2.25 = 11.25 division : 5 / 2.25 = 2.2222223
- Complex Numbers: The complex numbers are divided into two parts are shown in the below table. float32 and float64 are also part of these complex numbers. The in-built function creates a complex number from its imaginary and real part and in-built imaginary and real function extract those parts.
- There are few built-in functions in complex numbers:
- complex – make complex numbers from two floats.
- real() – get real part of the input complex number as a float number.
- imag() – get imaginary of the input complex number part as float number
- There are few built-in functions in complex numbers:
Data Type |
Description |
---|---|
complex64 | Complex numbers which contain float32 as a real and imaginary component. |
complex128 | Complex numbers which contain float64 as a real and imaginary component. |
Example:
Go
// Go program to illustrate // the use of complex numbers package main import "fmt" Â
func main() {         var a complex128 = complex( 6 , 2 )    var b complex64 = complex( 9 , 2 )    fmt.Println(a)    fmt.Println(b)        // Display the type   fmt.Printf( "The type of a is %T and " +             "the type of b is %T" , a, b) } |
Output:Â
(6+2i) (9+2i) The type of a is complex128 and the type of b is complex64
Built-in functions example :
Go
// Built-in functions in complex numbers // Author : Chhanda Saha package main Â
import "fmt" Â
func main() {     comp1 := complex( 10 , 11 )     // complex number init syntax     comp2 := 13 + 33i     fmt.Println( "Complex number 1 is :" , comp1)     fmt.Println( "Complex number 1 is :" , comp2)     // get real part     realNum := real(comp1)     fmt.Println( "Real part of complex number 1:" , realNum)     // get imaginary part     imaginary := imag(comp2)     fmt.Println( "Imaginary part of complex number 2:" , imaginary) Â
} |
Output:
Complex number 1 is : (10+11i) Complex number 1 is : (13+33i) Real part of complex number 1: 10 Imaginary part of complex number 2: 33
Booleans
The boolean data type represents only one bit of information either true or false. The values of type boolean are not converted implicitly or explicitly to any other type.Â
Example:Â
Go
// Go program to illustrate // the use of booleans package main import "fmt" Â
func main() {          // variables    str1 := "GeeksforGeeks"    str2:= "geeksForgeeks"    str3:= "GeeksforGeeks"    result1:= str1 == str2    result2:= str1 == str3        // Display the result    fmt.Println( result1)    fmt.Println( result2)        // Display the type of    // result1 and result2    fmt.Printf( "The type of result1 is %T and " +                    "the type of result2 is %T" ,                              result1, result2)     } |
Output:
false true The type of result1 is bool and the type of result2 is bool
Strings
The string data type represents a sequence of Unicode code points. Or in other words, we can say a string is a sequence of immutable bytes, means once a string is created you cannot change that string. A string may contain arbitrary data, including bytes with zero value in the human-readable form. Strings can be concatenated using plus(+) operator.
Example:Â
Go
// Go program to illustrate // the use of strings package main import "fmt" Â
func main() {          // str variable which stores strings    str := "GeeksforGeeks"        // Display the length of the string    fmt.Printf( "Length of the string is:%d" ,                                   len(str))        // Display the string    fmt.Printf( "\nString is: %s" , str)        // Display the type of str variable    fmt.Printf( "\nType of str is: %T" , str) } |
Output:Â
Length of the string is:13 String is: GeeksforGeeks Type of str is: string
String concatenation example:
Go
// String concatenation // Author : Chhanda Saha package main Â
import "fmt" Â
func main() { Â Â Â Â var str1 string = "STRING_" Â Â Â Â var str2 string = "Concatenation" Â
    // Concatenating strings using + operator     fmt.Println( "New string : " , str1+str2) Â
} |
Output:
New string : STRING_Concatenation
Â