Prev Next

Golang / GoLang Basics Interview Questions

How do interfaces work in Go? How do you use type assertions and type switches?

An interface specifies a set of method signatures. Any type that implements all the methods satisfies the interface — implicitly, with no declaration. This is sometimes called structural typing or duck typing with static checking.

// Interface definition
type Shape interface {
    Area()      float64
    Perimeter() float64
}

// Circle satisfies Shape — no 'implements' keyword needed
type Circle struct{ Radius float64 }
func (c Circle) Area()      float64 { return math.Pi * c.Radius * c.Radius }
func (c Circle) Perimeter() float64 { return 2 * math.Pi * c.Radius }

type Rectangle struct{ W, H float64 }
func (r Rectangle) Area()      float64 { return r.W * r.H }
func (r Rectangle) Perimeter() float64 { return 2 * (r.W + r.H) }

// Polymorphic function — accepts any Shape
func printShape(s Shape) {
    fmt.Printf("Area=%.2f Perimeter=%.2f\n", s.Area(), s.Perimeter())
}

shapes := []Shape{Circle{5}, Rectangle{4, 6}}
for _, s := range shapes { printShape(s) }

// Type assertion — extract concrete type (safe form)
var s Shape = Circle{Radius: 3}
c, ok := s.(Circle)
if ok { fmt.Println("radius:", c.Radius) }  // radius: 3

// Type switch — check and handle multiple types
switch v := s.(type) {
case Circle:    fmt.Printf("circle r=%.1f\n", v.Radius)
case Rectangle: fmt.Printf("rect %.0fx%.0f\n", v.W, v.H)
default:        fmt.Println("unknown shape")
}

// Compile-time interface check (zero-cost assertion)
var _ Shape = Circle{}  // COMPILE ERROR if Circle doesn't implement Shape
What keyword does a Go type use to declare that it implements an interface?
What does a safe type assertion 'c, ok := s.(Circle)' do when s does not hold a Circle?

Invest now in Acorns!!! 🚀 Join Acorns and get your $5 bonus!

Invest now in Acorns!!! 🚀
Join Acorns and get your $5 bonus!

Earn passively and while sleeping

Acorns is a micro-investing app that automatically invests your "spare change" from daily purchases into diversified, expert-built portfolios of ETFs. It is designed for beginners, allowing you to start investing with as little as $5. The service automates saving and investing. Disclosure: I may receive a referral bonus.

Invest now!!! Get Free equity stock (US, UK only)!

Use Robinhood app to invest in stocks. It is safe and secure. Use the Referral link to claim your free stock when you sign up!.

The Robinhood app makes it easy to trade stocks, crypto and more.


Webull! Receive free stock by signing up using the link: Webull signup.

More Related questions...

What is Go and why was it created at Google? What are the key characteristics that make Go different from other popular languages? What are packages in Go and what is special about the 'main' package? What are the different ways to declare variables in Go? What are the fundamental data types in Go? How do constants and iota work in Go? How are functions defined in Go? What are variadic functions and named return values? How do if, for, and switch statements work in Go? What is the difference between arrays and slices in Go? How do maps work in Go? What are the key operations and pitfalls? How do structs work in Go and how do you attach methods to them? How do interfaces work in Go? How do you use type assertions and type switches? What is the empty interface (any / interface{}) and when should you use it? How do pointers work in Go and how are they safer than C pointers? How does Go handle errors, and what is the difference between %v and %w in fmt.Errorf? What are goroutines and how do you use sync.WaitGroup to wait for them? What are channels in Go and what is the difference between buffered and unbuffered? How do defer, panic, and recover work together in Go? What are closures in Go and what is the loop variable capture gotcha? What is the init() function and when does it run? What is the Go module system? What do go.mod and go.sum contain? What is a data race in Go and how do you detect one? What is the fmt.Stringer interface and how does it control how a type is printed? What is the difference between a type definition and a type alias in Go? How does Go handle strings, runes, and bytes? Why is len(s) not the character count? What is a goroutine leak and what is the idiomatic way to prevent one? What is sync.Mutex and when do you use sync.RWMutex instead? How does struct embedding promote methods in Go, and how does it differ from inheritance? How does append() work internally in Go? When does it allocate new memory? What is context.Context and why is it the first parameter in so many Go functions? What is the 'typed nil' trap in Go and why does 'if err != nil' sometimes fail? What are the most important formatting verbs in Go's fmt package?
Show more question and Answers...

Golang Internals and Memory Management Interview Questions

Comments & Discussions