Gocloudcoder replies to books to receive learning materials, including Linux, Golang, Java, JS, operating systems, computer networks, programming experience, algorithms and data structures, etc.
Two papers
In 1976, Swiss computer scientist Algol W Modula, Oberon and Niklaus Emil Wirth, the designer of Pascal, wrote a classic book Titled Algorithms + Data Structures = Programs (linked to 1985 edition), Algorithm + data structure = program.
This book mainly deals with the relationship between algorithms and data structures. This book has a profound influence on computer science, especially in computer science education. In 1979, Robert Kowalski, a British logician and computer scientist, published the paper Algorithm = Logic + Control, and mainly developed “Logic programming” related work.
Robert Kowalski was a logician and computer scientist who worked on databases from the late 1970s through the 1980s and was instrumental in the use of computers to prove mathematical theorems and other important applications of the year, especially in developing revolutionary theories on logic, control and algorithms. It has greatly influenced databases, programming languages, and even artificial intelligence today.
Robert Kowalski writes in this paper:
Any algorithm will have two parts, one is Logic, which is used to solve practical problems.
The other is the Control section, which is used to decide what strategy to use to solve the problem.
The Logic part is really the algorithm to solve the problem, while the Control part only affects the efficiency of solving the problem.
The efficiency of a program has nothing to do with its logic.
We believe that if the Logic and Control parts are effectively separated, the code becomes easier to improve and maintain.
Note that the last sentence is the point — if the Logic and Control parts are effectively separated, the code becomes much easier to improve and maintain.
The nature of programming
Two expressions for two old gentlemen:
-
Programs = Algorithms + Data Structures
-
Algorithm = Logic + Control
The first expression tends towards data structures and algorithms, and it tries to split the two, which was the way it was going in the early days.
They argue that if the data structure is well designed, the algorithm will be simple, and that a good general algorithm should be able to be applied to different data structures.
The second expression expresses that the data structure is not complex, but the algorithm is complex, that is, our business logic is complex.
Our algorithm consists of two logic, one is true business logic and the other is control logic.
There are two kinds of code in the program, one is the real business logic code, and the other is the code that controls our program, called control code, which is not business logic at all, business logic doesn’t care about that.
The efficiency of the algorithm can often be achieved by improving the efficiency of the control part without changing the logic part and therefore the meaning of the algorithm.
Let’s take a factorial example, X(n) factorial. = X(n) * X(n-1) * X(n-2) * X(n-3)*… Times 3 times 2 times 1.
The logical part is used to define factorial:
-
1 is the factorial of 0;
-
If v is x factorial, and u is v times x plus 1, then u is x plus 1 factorial
Using this definition, you can either reduce the factorial of x+1 from the top down to compute x factorial first and multiply the result by one (recursive), or you can calculate a series of factorial results one by one from the bottom up (iteration).
The control section describes how logic is used. The crudest view can be that “control” is a strategy to solve a problem without changing the meaning of the algorithm, which is determined by logic.
For the same logic, using different controls, the resulting algorithms are essentially equivalent, because they solve the same problem and get the same result.
Therefore, we can improve the efficiency of the algorithm, maintain its logic, and make better use of the logic through logical analysis.
Sometimes, for example, top-down control instead of bottom-up control can improve efficiency.
Moving from top-down sequential execution to parallel execution also improves efficiency.
In short, through these two expressions, we can conclude:
Program = Logic + Control + Data Structure
Almost every language or programming paradigm addresses this problem. Here are a few things:
- Control can be standardized. For example, data traversal, data lookup, multi-threading, concurrency, asynchrony, etc., can be standardized
- Because Control has to deal with Data, so standardizing Control, standardizing Data Structure, we can do that with generic programming
- Control also handles the user’s business Logic, known as Logic. So, we can do this by standardizing interfaces/protocols, and our Control mode can be adapted to any Logic
These three points are the essence of the programming paradigm.
-
Separating Logic, Control, and Data effectively is the key to writing good programs!
-
Separating Logic, Control, and Data effectively is the key to writing good programs!
-
Separating Logic, Control, and Data effectively is the key to writing good programs!
When we write code, we see a lot of code that puts control logic and business logic together.
Some of these variables and processes are business relevant and some are not.
Business logic determines the complexity of the program, and as business logic is complex, you can’t write simple code.
Logic, which is the lower limit of the complexity of the program, then we need to make a lot of Control code in order to Control the program, so the interweaving of Logic+Control becomes the final complexity of the program.
An example of confusing logic with control
Take bubbling sort as an example.
func sortMaoPao(nums []int) []int {
var temp int
for i := 0; i < len(nums); i++ {
for j := i + 1; j < len(nums); j++ {
if nums[i] > nums[j] {
//nums[i], nums[j] = nums[j], nums[i]
temp = nums[i]
nums[i] = nums[j]
nums[j] = temp
}
}
}
return nums
}
Copy the code
The logic of sorting is nothing more than traversing, comparing sizes, swapping.
Then we can abstract logic out. Easy to reuse other sort of code, but also more conducive to understand the program!
Such as sorting data in many other data structures, such as structures, the code can be reused, which is the benefit of the interface approach.
Write three interface methods:
- Len() int Returns the length
- Less(I, j int) bool Indicates whether the data with I is Less than the data with subscript j
- Swap(I, j int) Swap
package main
import "fmt"
type sorter interface {
Len() int
Less(i, j int) bool
Swap(i, j int)}type data struct {
nums []int
}
func main(a) {
d := &data{[]int{1.3.2.4.6}}
sortMaoPao(d)
fmt.Println(*d) //[1, 2, 3, 4, 6]
}
func (d data) Len(a) int {
return len(d.nums)
}
func (d data) Less(i, j int) bool {
if d.nums[i] > d.nums[j] {
return true
}
return false
}
func (d *data) Swap(i, j int) {
var temp int
temp = d.nums[i]
d.nums[i] = d.nums[j]
d.nums[j] = temp
}
func sortMaoPao(s sorter) {
length := s.Len()
for i := 0; i < length; i++ {
for j := i + 1; j < length; j++ {
if s.Less(i, j) {
s.Swap(i, j)
}
}
}
}
Copy the code
Even though we have more code, we have completely separated logic from control.
Len() is for size only, Less() is for size only, and Swap() is for swaps only.
Interface usage is also written for code reuse.
We’re going for high quality code, not just writing it!
recommended
I summarized some commonly used programming books and the big guy’s 20 years of programming experience.
Very helpful for learning!
The official account replied: books for collection