130 lines
5.4 KiB
Markdown
130 lines
5.4 KiB
Markdown
|
# Required Reading
|
||
|
|
||
|
This chapter lists a few books that should be read by everyone working on
|
||
|
Memgraph. Since Memgraph is developed primarily with C++, Python and Common
|
||
|
Lisp, books are oriented around those languages. Of course, there are plenty
|
||
|
of general books which will help you improve your technical skills (such as
|
||
|
"The Pragmatic Programmer", "The Mythical Man-Month", etc.), but they are not
|
||
|
listed here. This way the list should be kept short and the *required* part in
|
||
|
"Required Reading" more easily honored.
|
||
|
|
||
|
Some of these books you may find in our office, so feel free to pick them up.
|
||
|
If any are missing and you would like a physical copy, don't be afraid to
|
||
|
request the book for our office shelves.
|
||
|
|
||
|
Besides reading, don't get stuck in a rut and be a
|
||
|
[Blub Programmer](http://www.paulgraham.com/avg.html).
|
||
|
|
||
|
## Effective C++ by Scott Meyers
|
||
|
|
||
|
Required for C++ developers.
|
||
|
|
||
|
The book is a must-read as it explains most common gotchas of using C++. After
|
||
|
reading this book, you are good to write competent C++ which will pass code
|
||
|
reviews easily.
|
||
|
|
||
|
## Effective Modern C++ by Scott Meyers
|
||
|
|
||
|
Required for C++ developers.
|
||
|
|
||
|
This is a continuation of the previous book, it covers updates to C++ which
|
||
|
came with C++11 and later. The book isn't as imperative as the previous one,
|
||
|
but it will make you aware of modern features we are using in our codebase.
|
||
|
|
||
|
## Practical Common Lisp by Peter Siebel
|
||
|
|
||
|
Required for Common Lisp developers.
|
||
|
|
||
|
Free: http://www.gigamonkeys.com/book/
|
||
|
|
||
|
We use Common Lisp to generate C++ code and make our lives easier.
|
||
|
Unfortunately, not many developers are familiar with the language. This book
|
||
|
will make you familiar very quickly as it has tons of very practical
|
||
|
exercises. E.g. implementing unit testing library, serialization library and
|
||
|
bundling all that to create a mp3 music server.
|
||
|
|
||
|
## Effective Python by Brett Slatkin
|
||
|
|
||
|
(Almost) required reading for Python developers.
|
||
|
|
||
|
Why the "almost"? Well, Python is relatively easy to pick up and you will
|
||
|
probably learn all the gotchas during code review from someone more
|
||
|
experienced. This makes the book less necessary for a newcomer to Memgraph,
|
||
|
but the book is not advanced enough to delegate it to
|
||
|
[Advanced Reading](#advanced-reading). The book is written in similar vein as
|
||
|
the "Effective C++" ones and will make you familiar with nifty Python features
|
||
|
that make everyone's lives easier.
|
||
|
|
||
|
# Advanced Reading
|
||
|
|
||
|
The books listed below are not required reading, but you may want to read them
|
||
|
at some point when you feel comfortable enough.
|
||
|
|
||
|
## Design Patterns by Gamma et. al.
|
||
|
|
||
|
Recommended for C++ developers.
|
||
|
|
||
|
This book is highly divisive because it introduced a culture centered around
|
||
|
design patterns. The main issues is overuse of patterns which complicates the
|
||
|
code. This has made many Java programs to serve as examples of highly
|
||
|
complicated, "enterprise" code.
|
||
|
|
||
|
Unfortunately, design patterns are pretty much missing
|
||
|
language features. This is most evident in dynamic languages such as Python
|
||
|
and Lisp, as demonstrated by
|
||
|
[Peter Norvig](http://www.norvig.com/design-patterns/).
|
||
|
|
||
|
Or as [Paul Graham](http://www.paulgraham.com/icad.html) put it:
|
||
|
|
||
|
```
|
||
|
This practice is not only common, but institutionalized. For example, in the
|
||
|
OO world you hear a good deal about "patterns". I wonder if these patterns are
|
||
|
not sometimes evidence of case (c), the human compiler, at work. When I see
|
||
|
patterns in my programs, I consider it a sign of trouble. The shape of a
|
||
|
program should reflect only the problem it needs to solve. Any other
|
||
|
regularity in the code is a sign, to me at least, that I'm using abstractions
|
||
|
that aren't powerful enough-- often that I'm generating by hand the expansions
|
||
|
of some macro that I need to write
|
||
|
```
|
||
|
|
||
|
After presenting the book so negatively, why you should even read it then?
|
||
|
Well, it is good to be aware of those design patterns and use them when
|
||
|
appropriate. They can improve modularity and reuse of the code. You will also
|
||
|
find examples of such patterns in our code, primarily Strategy and Visitor
|
||
|
patterns. The book is also a good stepping stone to more advanced reading
|
||
|
about software design.
|
||
|
|
||
|
## Modern C++ Design by Andrei Alexandrescu
|
||
|
|
||
|
Recommended for C++ developers.
|
||
|
|
||
|
This book can be treated as a continuation of the previous "Design Patterns"
|
||
|
book. It introduced "dark arts of template meta-programming" to the world.
|
||
|
Many of the patterns are converted to use C++ templates which makes them even
|
||
|
better for reuse. But, like the previous book, there are downsides if used too
|
||
|
much. You should approach it with a critical eye and it will help you
|
||
|
understand ideas that are used in some parts of our codebase.
|
||
|
|
||
|
## Large Scale C++ Software Design by John Lakos
|
||
|
|
||
|
Recommended for C++ developers.
|
||
|
|
||
|
An old book, but well worth the read. Lakos presents a very pragmatic view of
|
||
|
writing modular software and how it affects both development time as well as
|
||
|
program runtime. Some things are outdated or controversial, but it will help
|
||
|
you understand how the whole C++ process of working in a large team, compiling
|
||
|
and linking affects development.
|
||
|
|
||
|
## On Lisp by Paul Graham
|
||
|
|
||
|
Recommended for Common Lisp developers.
|
||
|
|
||
|
Free: http://www.paulgraham.com/onlisp.html
|
||
|
|
||
|
An excellent continuation to "Practical Common Lisp". It starts of slow, as if
|
||
|
introducing the language, but very quickly picks up speed. The main meat of
|
||
|
the book are macros and their uses. From using macros to define cooperative
|
||
|
concurrency to including Prolog as if it's part of Common Lisp. The book will
|
||
|
help you understand more advanced macros that are occasionally used in our
|
||
|
Lisp C++ Preprocessor (LCP).
|