The Go Programming Language
Autor Alan A. A. Donovan, Brian W. Kernighanen Limba Engleză Paperback – 30 oct 2015
Explorăm aici un titlu fundamental pentru înțelegerea ecosistemului Go, un limbaj proiectat pentru eficiență și simplitate în dezvoltarea sistemelor moderne. The Go Programming Language nu se limitează la prezentarea sintaxei, ci ne ghidează prin mecanismele interne ale bibliotecilor standard, oferind o perspectivă tehnică asupra modului în care pot fi construite programe robuste. Remarcăm o abordare practică încă din primul capitol, unde suntem introduși în dezvoltarea de servere web și instrumente pentru linia de comandă, elemente esențiale pentru orice inginer software. Structura volumului reflectă o progresie logică, pornind de la conceptele de bază precum declarațiile de variabile și tipurile de date fundamentale, trecând spre structuri compuse (slices, maps, structs) și ajungând la mecanisme complexe de control, cum sunt funcțiile variadice și gestionarea erorilor prin mecanismele de tip 'defer', 'panic' și 'recover'. Observăm că autorii pun un accent deosebit pe interoperabilitatea datelor, dedicând secțiuni specifice pentru lucrul cu JSON și template-uri HTML, componente vitale în serviciile web actuale. Complementar lui Beginning Go Programming, volumul de față acoperă nu doar fundamentele lingvistice, ci și filosofia de design a limbajului, explicând de ce anumite decizii arhitecturale fac din Go o soluție superioară pentru concurență. În timp ce alte ghiduri se concentrează pe o introducere rapidă, The Go Programming Language oferă rigoarea necesară pentru a scrie cod idiomatic, transformând dezvoltatorul într-un utilizator avansat al bibliotecilor standard. Experiența de lectură este una densă, orientată spre performanță și bune practici în ingineria software.
Preț: 272.98 lei
Preț vechi: 341.23 lei
-20%
Carte disponibilă
Livrare economică 04-18 mai
Livrare express 17-23 aprilie pentru 45.17 lei
Specificații
ISBN-10: 0134190440
Pagini: 400
Dimensiuni: 195 x 235 x 22 mm
Greutate: 0.76 kg
Editura: ADDISON-WESLEY
De ce să citești această carte
Recomandăm această carte inginerilor software care doresc să stăpânească limbajul Go dincolo de nivelul de începător. Cititorul câștigă o înțelegere profundă a modului în care funcționează bibliotecile standard și învață să aplice tehnici de design eficiente. Este resursa definitivă pentru cei care vor să scrie cod curat, concurent și performant, beneficiind de expertiza unor autori care au modelat istoria programării moderne.
Despre autor
Alan A. A. Donovan este membru al echipei Google Go din New York, având o contribuție majoră în designul bibliotecilor și instrumentelor de analiză pentru acest limbaj. Brian W. Kernighan este un nume legendar în informatică, fiind profesor la Universitatea Princeton și co-autor al cărții clasice despre limbajul C. Experiența lor combinată oferă acestui volum o autoritate incontestabilă, transformând descrierea tehnică a limbajului într-o lecție de inginerie software aplicată și design de sisteme.
Descriere scurtă
- The first chapter is a tutorial on the basic concepts of Go, introduced through programs for file I/O and text processing, simple graphics, and web clients and servers.
- Early chapters cover the structural elements of Go programs: syntax, control flow, data types, and the organization of a program into packages, files, and functions. The examples illustrate many packages from the standard library and show how to create new ones of your own. Later chapters explain the package mechanism in more detail, and how to build, test, and maintain projects using the go tool.
- The chapters on methods and interfaces introduce Go s unconventional approach to object-oriented programming, in which methods can be declared on any type and interfaces are implicitly satisfied. They explain the key principles of encapsulation, composition, and substitutability using realistic examples.
- Two chapters on concurrency present in-depth approaches to this increasingly important topic. The first, which covers the basic mechanisms of goroutines and channels, illustrates the style known as communicating sequential processes for which Go is renowned. The second covers more traditional aspects of concurrency with shared variables. These chapters provide a solid foundation for programmers encountering concurrency for the first time.
- The final two chapters explore lower-level features of Go. One covers the art of metaprogramming using reflection. The other shows how to use the unsafe package to step outside the type system for special situations, and how to use the cgo tool to create Go bindings for C libraries.
Notă biografică
Brian W. Kernighan is a professor in the Computer Science Department at Princeton University. He was a member of technical staff in the Computing Science Research Center at Bell Labs from 1969 until 2000, where he worked on languages and tools for Unix. He is the co-author of several books, including The C Programming Language, Second Edition (Prentice Hall, 1988), and The Practice of Programming (Addison-Wesley, 1999).
Cuprins
Chapter 1: Tutorial 1
1.1 Hello, World 1
1.2 Command-Line Arguments 4
1.3 Finding Duplicate Lines 8
1.4 Animated GIFs 13
1.5 Fetching a URL 15
1.6 Fetching URLs Concurrently 17
1.7 A Web Server 19
1.8 Loose Ends 23
Chapter 2: Program Structure 27
2.1 Names 27
2.2 Declarations 28
2.3 Variables 30
2.4 Assignments 36
2.5 Type Declarations 39
2.6 Packages and Files 41
2.7 Scope 45
Chapter 3: Basic Data Types 51
3.1 Integers 51
3.2 Floating-Point Numbers 56
3.3 Complex Numbers 61
3.4 Booleans 63
3.5 Strings 64
3.6 Constants 75
Chapter 4: Composite Types 81
4.1 Arrays 81
4.2 Slices 84
4.3 Maps 93
4.4 Structs 99
4.5 JSON 107
4.6 Text and HTML Templates 113
Chapter 5: Functions 119
5.1 Function Declarations 119
5.2 Recursion 121
5.3 Multiple Return Values 124
5.4 Errors 127
5.5 Function Values 132
5.6 Anonymous Functions 135
5.7 Variadic Functions 142
5.8 Deferred Function Calls 143
5.9 Panic 148
5.10 Recover 151
Chapter 6:. Methods 155
6.1 Method Declarations 155
6.2 Methods with a Pointer Receiver 158
6.3 Composing Types by Struct Embedding 161
6.4 Method Values and Expressions 164
6.5 Example: Bit Vector Type 165
6.6 Encapsulation 168
Chapter 7: Interfaces 171
7.1 Interfaces as Contracts 171
7.2 Interface Types 174
7.3 Interface Satisfaction 175
7.4 Parsing Flags with flag.Value 179
7.5 Interface Values 181
7.6 Sorting with sort.Interface 186
7.7 The http.Handler Interface 191
7.8 The error Interface 196
7.9 Example: Expression Evaluator 197
7.10 Type Assertions 205
7.11 Discriminating Errors with Type Assertions 206
7.12 Querying Behaviors with Interface Type Assertions 208
7.13 Type Switches 210
7.14 Example: Token-Based XML Decoding 213
7.15 A Few Words of Advice 216
Chapter 8: Goroutines and Channels 217
8.1 Goroutines 217
8.2 Example: Concurrent Clock Server 219
8.3 Example: Concu rent Echo Server 222
8.4 Channels 225
8.5 Looping in Parallel 234
8.6 Example: Concurrent Web Crawler 239
8.7 Multiplexing with select 244
8.8 Example: Concurrent Directory Traversal 247
8.9 Cancellation 251
8.10 Example: Chat Server 253
Chapter 9: Concurrency with Shared Variables 257
9.1 Race Conditions 257
9.2 Mutual Exclusion: sync.Mutex 262
9.3 Read/Write Mutexes: sync.RWMutex 266
9.4 Memory Synchronization 267
9.5 Lazy Initialization: sync.Once 268
9.6 The Race Detector 271
9.7 Example: Concurrent Non-Blocking Cache 272
9.8 Goroutines and Threads 280
Chapter 10: Packages and the Go Tool 283
10.1 Introduction 283
10.2 Import Paths 284
10.3 The Package Declaration 285
10.4 Import Declarations 285
10.5 Blank Imports 286
10.6 Packages and Naming 289
10.7 The Go Tool 290
Chapter 11: Testing 301
11.1 The go test Tool 302
11.2 Test Functions 302
11.3 Coverage 318
11.4 Benchmark Functions 321
11.5 Profiling 323
11.6 Example Functions 326
Chapter 12: Reflection 329
12.1 Why Reflection? 329
12.2 reflect.Type and reflect.Value 330
12.3 Display, a Recursive Value Printer 333
12.4 Example: Encoding S-Expressions 338
12.5 Setting Variables with reflect.Value 341
12.6 Example: Decoding S-Expressions 344
12.7 Accessing Struct Field Tags 348
12.8 Displaying the Methods of a Type 351
12.9 A Word of Caution 352
Chapter 13: Low-Level Programming 353
13.1 unsafe.Sizeof, Alignof, and Offsetof 354
13.2 unsafe.Pointer 356
13.3 Example: Deep Equivalence 358
13.4 Calling C Code with cgo 361
13.5 Another Word of Caution 366
Index 367