> For the complete documentation index, see [llms.txt](https://ineelhere.gitbook.io/code-with-go/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://ineelhere.gitbook.io/code-with-go/21-interfaces.md).

# Interfaces

This Go program demonstrates the use of interfaces and polymorphism. It defines an interface named `geometry` with methods `area` and `perim`. Two struct types, `rect` and `circle`, implement this interface by providing their own versions of the `area` and `perim` methods. The `measure` function takes a `geometry` interface as a parameter and calls its methods. Finally, in the `main` function, instances of `rect` and `circle` are created, and the `measure` function is called on each of them.

Let's go through each part of the code with inline comments and additional explanations:

```go
package main

import (
    "fmt"
    "math"
)

// Define an interface named 'geometry' with methods 'area' and 'perim'
type geometry interface {
    area() float64
    perim() float64
}

// Define a struct named 'rect' with two fields: 'width' and 'height'
type rect struct {
    width, height float64
}

// Define a struct named 'circle' with a field 'radius'
type circle struct {
    radius float64
}

// Implement the 'area' method for the 'rect' struct
func (r rect) area() float64 {
    return r.width * r.height
}

// Implement the 'perim' method for the 'rect' struct
func (r rect) perim() float64 {
    return 2*r.width + 2*r.height
}

// Implement the 'area' method for the 'circle' struct
func (c circle) area() float64 {
    return math.Pi * c.radius * c.radius
}

// Implement the 'perim' method for the 'circle' struct
func (c circle) perim() float64 {
    return 2 * math.Pi * c.radius
}

// Function 'measure' takes a 'geometry' interface and prints information about it
func measure(g geometry) {
    fmt.Println(g)
    fmt.Println("Area:", g.area())
    fmt.Println("Perimeter:", g.perim())
}

func main() {
    // Create an instance of the 'rect' struct
    r := rect{width: 3, height: 4}

    // Create an instance of the 'circle' struct
    c := circle{radius: 5}

    // Call 'measure' function for the 'rect' instance
    measure(r)

    // Call 'measure' function for the 'circle' instance
    measure(c)
}
```

#### Output

```
{3 4}
12
14
{5}
78.53981633974483
31.41592653589793
```

Explanation:

1. The `geometry` interface is defined with two methods, `area` and `perim`.
2. Two struct types, `rect` and `circle`, implement the `geometry` interface by providing their own versions of the `area` and `perim` methods.
3. The `measure` function takes a parameter of type `geometry` and prints information about it, including calling the `area` and `perim` methods.
4. In the `main` function:
   * An instance of the `rect` struct (`r`) and an instance of the `circle` struct (`c`) are created.
   * The `measure` function is called for both the `rect` and `circle` instances, demonstrating polymorphism. The function can work with any type that implements the `geometry` interface, allowing for flexibility and code reusability.


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter, and the optional `goal` query parameter:

```
GET https://ineelhere.gitbook.io/code-with-go/21-interfaces.md?ask=<question>&goal=<endgoal>
```

`ask` is the immediate question: it should be specific, self-contained, and written in natural language.
`goal` is optional and describes the broader end goal you are ultimately trying to accomplish on behalf of the user. GitBook uses it to tailor the answer towards what is most useful for that goal.

The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
