-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathoop-in-go.slide
354 lines (237 loc) · 15.6 KB
/
oop-in-go.slide
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
Object Oriented Principles in Go
26 Apr 2017
Ivan Kutuzov
https://discuss.7insyde.com
https://golang.org.ua
@arbrix
* License and Materials
This presentation is licensed under the [[https://creativecommons.org/licenses/by-sa/4.0/][Creative Commons Attribution-ShareAlike 4.0 International]] licence.
The materials for this presentation are available on GitHub:
.link https://github.com/GolangUA/go-training
You are encouraged to remix, transform, or build upon the material, providing you give appropriate credit and distribute your contributions under the same license.
If you have suggestions or corrections to this presentation, please raise [[https://github.com/GolangUA/go-training/issues][an issue on the GitHub project]].
* Agenda
- Recap / Homework
- Basic Principles
- Golang difference
- SOLID
* Previous Sessions
* On the previous session
- Who use Go
- Imperative programs
- Go Environment (Workspace)
- Go Operators
- Basic Syntax
- Advanced Syntax
- Homework
* The Go programming language
- Modern
- Compact, concise, general-purpose
- Imperative, statically type-checked, dynamically type-safe
- Garbage-collected
- Compiles to native code, statically linked
- Fast compilation, efficient execution
* Go Operators
- Arithmetic Operators
- Relational Operators
- Logical Operators
- Bitwise Operators
- Assignment Operators
- Misc Operators
[[https://www.tutorialspoint.com/go/go_operators.htm][Go Operators]]
* Basic Syntax
- Declarations
- Loops and conditions
- Control Flow
- User Types
- User Function
- Packages
* Advanced Syntax
- How Go code is formatted.
- How what the zero value is and how it works.
- Equality and type conversions
- The short declaration syntax
- Multiple assignment.
- How slices, maps work.
- How the `fmt` package works.
- Scope
- Struct, Pointers, Nil
- Interfaces
- Defer
- Documenting
* Homework
* Object Oriented Principles
* Object Oriented Principles
Software design is about representation: how do we represent the solution to a problem in code that can be executed on the machine of our choice? How do we represent the problem domain to the user?
Creating a software representation that can be usefully viewed as isomorphic with some aspect of the real world is a common software design task.
.link https://www.activestate.com/blog/2017/03/go-object-oriented-developers source
* Object Oriented Principles
Object-oriented programming (OOP) is a programming paradigm based on the concept of "objects", which may contain data, in the form of fields, often known as attributes; and code, in the form of procedures, often known as methods. A feature of objects is that an object's procedures can access and often modify the data fields of the object with which they are associated.
.link https://en.wikipedia.org/wiki/Object-oriented_programming source
Object orientation is an approach to software development in which we focus on objects and their attributes and responsibilities. All business problems involve things. These things can be mapped to a set of objects, such as customers, invoices, etc. In any given business problem the various things have attributes like name, color, weight, etc and they have responsibilities such as initiate and order, fulfill an order, pay an invoice, etc.
.link http://www.jamesbooth.com/OOPBasics.htm source
* Object Oriented Principles
- Abstraction
- Specialization
- Encapsulation
- Inheritance
- Polymorphism
* Attribution
This is the ability to represent a complex problem in simple terms. In the object oriented approach it is seen in the ability to create a high level class definition that has little or no detail included in it. We are able to “abstract” the problem to a simple class definition and only add detail alter in the process.
The ability to support abstraction is instrumental in being able to model very complex business problems in our designs.
* Specialization
Seen in class structures, specialization is the ability to make lower level subclasses more detailed than their parent classes. Technically, specialization is defined as the ability of an object to inherit operations and attributes from a superclass (parent class) with possible restrictions and additions.
* Encapsulation
Defined as hiding the implementation of the object, encapsulation is really the process of making an object as self sufficient as is possible. An object contains not only code but also data. Encapsulation, in the structured design, is the process of enclosing all of the code necessary to a particular operation into a single module and limiting the external dependencies of that module.
- There are two levels of access - within the package alone, and public.
- tarts with a capital letter it is exported outside the package and is public. If instead it starts with a small letter, it is visible only within the package.
- Exported/public items: MyStruct, MyMethod, MyField
- Items with package visibility: myStruct, myMethod, myField
- You can tie in methods/behavior to a type by defining functions associated with it. func (m my_type) my_func() int { }
- You cannot attach methods to a type if it is not defined in the local package.
* Inheritance
Just as you and I have inherited certain traits from our ancestors, so do classes in an object oriented system. There are superclasses (classes that have subclasses) and there are subclasses (classes that inherit form another class). These terms, superclass and subclass, are relative in that a given class may be a subclass of one class and a superclass for another.
_Inheritance_: the ability for one type to obtain the features of a type above it in a hierarchy. For Go, some of the salient features are:
- Inheritance is obtained through anonymous fields - anonymous fields appear to attach its behavior to the composing class.
- Both data fields and methods are available to derived types. Outside of the package, only the types, fields, and methods named with a starting capital letter is inherited. Inside a package, everything is inherited.
- Multiple inheritance is possible - by including an anonymous field of each of the parent types. `type Child struct { Father; Mother }`
* Polymorphism
_Polymorphism_: when a type seems to exhibit different behaviors when linked to different instances, the type can be said to exhibit polymorphism.
- Interfaces in Go can be used to implement polymorphism. A variable of a type can be assigned to a variable of any interface it implements.
* Representation in Go
Golang makes a number of design choices that distinguish it from other languages and make it a flexible, powerful, and relatively safe tool for representing a wide range of things.
- ability to add methods to any type except primitives
- interfaces
- structs
* Methods in Go
Go is a very strongly typed language, to the extent that even ints and floats won't interoperate without explicit casting. Types have a number of different aspects, however, that make them very flexible.
In Go, because methods are not part of the type and can be defined anywhere, a separate discipline must be practiced to ensure that the methods (verbs) we define on types (nouns) add up to a more-or-less coherent representation of whatever aspect of the world it is that is being represented by the type.
.link https://www.activestate.com/blog/2017/03/go-object-oriented-developers Methods in Go
* Interfaces
The next interesting bit of the language is interfaces, which have two roles in Go: enforcing duck-like typing at compile time and allowing dynamic dispatch.
Duck typing is the Pythonic concept that if it walks and talks like a duck, it is a duck: if an object has an interface that conforms to something, it is a thing of that type.
This might also be called "syntactical typing", as all that matters is the syntax of the call.
The problem with the Pythonic way of doing things is that there is no way of telling if a type conforms to an interface until it doesn't.
Interfaces allow Go programs to be checked at compile time to see if an object has all the methods required for a given interface, without further constraining the type.
* Structs
As the name suggests, a struct is more like a C struct than a C++ class. Structs allow data to be grouped together in convenient representational form, and permit a limited form of inheritance.
Structs take subtypes by declaring anonymous members rather than an explicit inheritance syntax.
Go simply recognizes anonymous members at the start of a struct declaration as base types for the struct, and allows the fields of the base types to be accessed directly.
* OOP in Golang
- Interface Contract
- Interface Type
- Interface Satisfaction
- Interface Value
- Type Assertation
- Type Switches
- Interface with Nil Pointer is Non-Nil
* Interface with Nil Pointer is Non-Nil
A nil interface value, which contains no value at all, is not the same as an interface value con- taining a pointer that happens to be nil. This subtle distinction creates a trap into which every Go programmer has stumbled.
const debug = true
func main() {
var buf *bytes.Buffer
if debug {
buf = new(bytes.Buffer) // enable collection of output
}
f(buf) // NOTE: subtly incorrect!
}
// If out is non-nil, output will be written to it.
func f(out io.Writer) {
// ...do something...
if out != nil {
out.Write([]byte("done!\n"))
}
}
* How to fix that?
* Use Interface for avoiding the assigment
var buf io.Writer
if debug {
buf = new(bytes.Buffer) // enable collection of output
}
f(buf) // OK
* Type Conversion
func sum(f float32) int32 {
return int32(f) + 10
}
* Type Assertation
func sum(i interface{}) int32 {
a, ok := i.(int32)
if !ok {
return errors.New("parameter should have int32 type")
}
return a + 10
}
* Type Switching
func (var interface{}) {
switch v := var.(type) {
case string:
s, _ := strconv.Atoi(v)
fmt.Println("sum: %d", s + 10)
case int:
fmt.Println("%d", v+10)
}
}
* Object-Oriented Programming in Golang
.link http://golangtutorials.blogspot.com/2011/06/structs-in-go-instead-of-classes-in.html Struct in Go
.link http://golangtutorials.blogspot.com/2011/06/anonymous-fields-in-structs-like-object.html Anonymous fields in structs - like object composition
.link http://golangtutorials.blogspot.com/2011/06/methods-on-structs.html Methods on structs
.link http://golangtutorials.blogspot.com/2011/06/inheritance-and-subclassing-in-go-or.html Inheritance and subclassing in Go
.link http://golangtutorials.blogspot.com/2011/06/interfaces-in-go.html Interfaces in Go
.link http://golangtutorials.blogspot.com/2011/06/polymorphism-in-go.html Polymorphism in Go
.link https://code.tutsplus.com/tutorials/lets-go-object-oriented-programming-in-golang--cms-26540 Object-Oriented Programming in Golang
* SOLID
In 2002 Robert Martin published his book, [[https://www.amazon.co.uk/dp/0135974445/ref=pd_lpo_sbs_dp_ss_2/253-1946330-6751666?pf_rd_m=A3P5ROKL5A1OLE&pf_rd_s=lpo-top-stripe&pf_rd_r=23C4AHYV7EXGYHKD6G8Q&pf_rd_t=201&pf_rd_p=569136327&pf_rd_i=0132760584][Agile Software Development, Principles, Patterns, and Practices.]] In it he described five principles of reusable software design, which he called the SOLID principles, after the first letters in their names.
- Single Responsibility Principle
- Open / Closed Principle
- Liskov Substitution Principle
- Interface Segregation Principle
- Dependency Inversion Principle
* Single Responsibility Principle
A class should have one, and only one, reason to change.
–Robert C Martin
Now Go obviously doesn’t have classes—instead we have the far more powerful notion of composition—but if you can look past the use of the word class.
Code that has a single responsibility therefore has the fewest reasons to change.
Doug McIlroy’s Unix philosophy; small, sharp tools which combine to solve larger tasks, oftentimes tasks which were not envisioned by the original authors.
* Open / Closed Principle
Software entities should be open for extension, but closed for modification.
–Bertrand Meyer, Object-Oriented Software Construction
Embedding isn’t just for methods, it also provides access to an embedded type’s fields. As you see, because both `A` and `B` are defined in the same package, `B` can access `A`‘s private year field as if it were declared inside `B`.
So embedding is a powerful tool which allows Go’s types to be open for extension.
.link https://dave.cheney.net/2016/08/20/solid-go-design source
* Liskov Substitution Principle
Coined by Barbara Liskov, the Liskov substitution principle states, roughly, that two types are substitutable if they exhibit behaviour such that the caller is unable to tell the difference.
In a class based language, Liskov’s substitution principle is commonly interpreted as a specification for an abstract base class with various concrete subtypes. But Go does not have classes, or inheritance, so substitution cannot be implemented in terms of an abstract class hierarchy.
Require no more, promise no less.
–Jim Weirich
* Interface Segregation Principle
Clients should not be forced to depend on methods they do not use.
–Robert C. Martin
The application of the interface segregation principle can refer to a process of isolating the behaviour required for a function to do its job.
pplying the interface segregation principle to our Save function, the results has simultaneously been a function which is the most specific in terms of its requirements–it only needs a thing that is writable–and the most general in its function, we can now use Save to save our data to anything which implements io.Writer.
A great rule of thumb for Go is accept interfaces, return structs.
–Jack Lindamood
* Dependency Inversion Principle
High-level modules should not depend on low-level modules. Both should depend on abstractions.
Abstractions should not depend on details. Details should depend on abstractions.
–Robert C. Martin
If you’ve applied all the principles we’ve talked about up to this point then your code should already be factored into discrete packages, each with a single well defined responsibility or purpose. Your code should describe its dependencies in terms of interfaces, and those interfaces should be factored to describe only the behaviour those functions require. In other words, there shouldn’t be much left to do.
So what I think Martin is talking about here, certainly the context of Go, is the structure of your import graph.
In Go, your import graph must be acyclic. A failure to respect this acyclic requirement is grounds for a compilation failure, but more gravely represents a serious error in design.
* Recap
- Object Oriented Principle
- Struct, Interface
- SOLID
* Questions?
* Resources
.link https://www.activestate.com/blog/2017/03/go-object-oriented-developers GO FOR OBJECT-ORIENTED DEVELOPERS
.link https://en.wikipedia.org/wiki/Object-oriented_programming Wiki
.link http://www.golangbootcamp.com/book Golang Bootcamp
.link https://www.youtube.com/watch?v=zzAdEt3xZ1M SOLID by Dave Cheney (Golang UK Conference 2016)
.link https://dave.cheney.net/2016/08/20/solid-go-design SOLID Go Design by Dave Cheney
.link https://code.tutsplus.com/tutorials/lets-go-object-oriented-programming-in-golang--cms-26540 Object Oriented Programming in Golang
.link https://www.goinggo.net/2013/07/object-oriented-programming-in-go.html Object Oriented Programming in Go
.link https://golang.org/doc/effective_go.html Effective Go
.link https://gobyexample.com/ Go by Example
.link https://miek.nl/go/ LEARNING GO online book
.link https://habrahabr.ru/hub/go/ Habrahabr