Skip to main content

Do you support us?

Business address
0x1D24D8f27ea73ff604C7685246bdC6ae55bddaEF

Receiver bind to special type of methods


Welcome, After a long time, I will share next article about advance methods that can increase problem efficiency, very useful . Let's begin this.

Method Value :
     Method Value are special type of methods. These methods don't receive receiver parameter. That why they are special methods. These are generally use in package level api or client defined behaviour. Let study example case i

package main

import (
"fmt"
)

type Op struct{
x int
}

func(o *Op)Add(y int)int{
return o.x +y
}

func main() {
// case i
op := Op{4}  // method value
res := op.Add
fmt.Println(res(4))

//case ii
oprend := &Op{5}   // method expression
add := (*oprend).Add
fmt.Println(add(4))
}

Method Expression:
        Method Expression are similar like to method values, but there is one great difference and is methods take parameter as a receiver, just like old example but you can bind with more than one methods. In method expression (*T).f is an unusual way to write a selector syntax . The above example( case ii) show both method expression but in next code you deeply understand.

type Point struct{ X, Y float64 }
func (p Point) Add(q Point) Point { return Point{p.X + q.X, p.Y + q.Y} }
func (p Point) Sub(q Point) Point { return Point{p.X - q.X, p.Y - q.Y} }
type Path []Point
func (path Path) TranslateBy(offset Point, add bool) {
  var op func(p, q Point) Point
   if add { op = Point.Add }
   else { op = Point.Sub }
   for i := range path {
          // Call either
       path[i].Add(offset)
               //or
       path[i].Sub(offset). path[i] = op(path[i], offset)
 }
}
I hope you enjoy, have a great day.


Comments

Popular posts from this blog

Rosicrucian cipher

In 1513 Cornelius Agrippa introduce early form Rosicrucian Cipher in his books Occult of Philosophy. Geometric and simple substitution cipher are well known ciphers      Pigpen , Freemason, Napoleon and tic tac toe ciphers in which alphabets or symbols arrange in grids.  This is an anagram, "How to reconstruct a data " lets encode the message.       Pigpen cipher , Rosicrucian and Tic tac toe Cipher                      Thank you have a good day.    

Life is all about decisions and repeat your routine

Life is all about Decisions and repeat our routine is an excellent idea which i show you within a moment. Everyday we take so many decisions based on environment conditions, circumstances. Each decision based on cause and effect philosophy. Programmer are wizards who create own world with data and structures. Without data or structure our world is nothing. Conditions: Conditions help us to take decision based under certain circumstances, such as if a number divisible by 2 at least two times then it's said to be double even. package main import ( "fmt" ) func main() { const divisible =2 var even int = 4 if even%divisible == 0 { n := even/divisible n /= divisible if n ==1 { fmt.Println("Doubly Even")  } }   } If you're a developer then you you know this code quite different from other languages syntax. In most languages, you see like this "if (condition)". Yeah it's different but this language compilati

Enumerate

Golang provide  own enumerate method which is easy and very powerful. I will show you enumerate with in a sec. When i code enumerate in java, believe me i don't understand why it's used? So i never play from this card at that time, but recently when i start learning go. Now i used where it's used and why? Enumerate basically a counting method. Code   package main import ( " fmt " ) type Weekend int const ( Sunday Weekend = iota Monday Tuesday Wednesday Thursday Friday Saturday ) func main () { fmt. Printf ( " %d " ,Saturday) } If you remember adding color layer then you familiar from this code.  First i create my own type called weekend then used this type.  Iota-generator:   Things that confuse you Sunday Weekend = iota & Monday without value. Before we start Iota-generator first we understand monday without type or value         const ( c = 1 // c : 1 d      // d : 1 ) fmt.Pr