Mastering Delphi Programming: A Complete Reference Guide Learn all about building fast, scalable, and high performing applications with Delphi Primož Gabrijelčič BIRMINGHAM - MUMBAI Mastering Delphi Programming: A Complete Reference Guide Copyright © 2019 Packt Publishing All rights reserved. No part of this book may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, without the prior written permission of the publisher, except in the case of brief quotations embedded in critical articles or reviews. Every effort has been made in the preparation of this book to ensure the accuracy of the information presented. However, the information contained in this book is sold without warranty, either express or implied. Neither the author, nor Packt Publishing or its dealers and distributors, will be held liable for any damages caused or alleged to have been caused directly or indirectly by this book. Packt Publishing has endeavored to provide trademark information about all of the companies and products mentioned in this book by the appropriate use of capitals. However, Packt Publishing cannot guarantee the accuracy of this information. First published: November 2019 Production reference: 1251119 Published by Packt Publishing Ltd. Livery Place 35 Livery Street Birmingham B3 2PB, UK. ISBN 978-1-83898-911-8 www.packtpub.com mapt.io Mapt is an online digital library that gives you full access to over 5,000 books and videos, as well as industry leading tools to help you plan your personal development and advance your career. For more information, please visit our website. Why subscribe? Spend less time learning and more time coding with practical eBooks and Videos from over 4,000 industry professionals Improve your learning with Skill Plans built especially for you Get a free eBook or video every month Mapt is fully searchable Copy and paste, print, and bookmark content PacktPub.com Did you know that Packt offers eBook versions of every book published, with PDF and ePub files available? You can upgrade to the eBook version at www.PacktPub.com and as a print book customer, you are entitled to a discount on the eBook copy. Get in touch with us at [email protected] for more details. At www.PacktPub.com, you can also read a collection of free technical articles, sign up for a range of free newsletters, and receive exclusive discounts and offers on Packt books and eBooks. Contributors About the author Primož Gabrijelčič started coding in Pascal on 8-bit micros in the 1980s and he never looked back. In the last 20 years, he was mostly programming high-availability server applications used in the broadcasting industry. A result of this focus was the open sourced parallel programming library for Delphi—OmniThreadLibrary. He's also an avid writer and has written several hundred articles, and he is a frequent speaker at Delphi conferences where he likes to talk about complicated topics, ranging from memory management to creating custom compilers. Packt is searching for authors like you If you're interested in becoming an author for Packt, please visit authors.packtpub.com and apply today. We have worked with thousands of developers and tech professionals, just like you, to help them share their insight with the global tech community. You can make a general application, apply for a specific hot topic that we are recruiting an author for, or submit your own idea. Table of Contents Preface 1 Chapter 1: About Performance 9 What is performance? 10 Different types of speed 11 Algorithm complexity 11 Big O and Delphi data structures 15 Data structures in practice 19 Mr. Smith's first program 24 Looking at code through the Big O eyes 27 Don't guess, measure! 30 Profiling with TStopwatch 31 Profilers 38 AsmProfiler 39 Sampling Profiler 47 AQTime 49 Nexus Quality Suite 52 Summary 56 Chapter 2: Fixing the Algorithm 57 Responsive user interfaces 58 Updating a progress bar 59 Bulk updates 62 Virtual display 66 Caching 70 Dynamic cache 73 Speeding up SlowCode 79 Summary 82 Chapter 3: Fine-Tuning the Code 83 Delphi compiler settings 84 Code inlining control 85 Optimization 86 Record field alignment 87 Assertions 90 Overflow checking 91 Range checking 91 Extracting common expressions 93 The helpful CPU window 95 Behind the scenes 97 A plethora of types 97 Table of Contents Simple types 98 Strings 99 Arrays 101 Records 103 Classes 107 Interfaces 108 Optimizing method calls 108 Parameter passing 109 Method inlining 114 The magic of pointers 116 Going the assembler way 121 Returning to SlowCode 123 Summary 125 Chapter 4: Memory Management 126 Optimizing strings and array allocations 127 Memory management functions 131 Dynamic record allocation 133 FastMM internals 138 Memory allocation in a parallel world 142 Replacing the default memory manager 147 ScaleMM 154 TBBMalloc 155 Fine-tuning SlowCode 157 Summary 159 Chapter 5: Getting Started with the Parallel World 161 Processes and threads 162 When to parallelize the code? 164 Most common problems 165 Never access UI from a background thread 166 Simultaneous reading and writing 169 Sharing a variable 171 Synchronization 175 Critical sections 176 Other locking mechanisms 182 A short note on coding style 188 Shared data with built-in locking 189 Interlocked operations 191 Object life cycle 194 Communication 197 Windows messages 198 Synchronize and Queue 202 Polling 203 Performance 205 [ ii ] Table of Contents Third-party libraries 206 Summary 208 Chapter 6: Working with Parallel Tools 209 TThread 209 Advanced TThread 215 Setting up a communication channel 218 Sending messages from a thread 222 Implementing a timer 225 Summary 230 Chapter 7: Exploring Parallel Practices 232 Tasks and patterns 233 Variable capturing 234 Tasks 236 Exceptions in tasks 239 Parallelizing a loop 242 Thread pooling 246 Async/Await 247 Join 251 Join/Await 254 Future 258 Parallel for 260 Pipelines 266 Creating the pipeline 268 Stages 271 Displaying the result and shutting down 275 Summary 276 Chapter 8: Using External Libraries 278 Using object files 279 Object file formats 281 Object file linking in practice 283 Using C++ libraries 287 Using a proxy DLL in Delphi 293 Summary 296 Chapter 9: Introduction to Patterns 298 Patterns in programming 298 Patterns are useful 300 Delphi idioms – Creating and destroying an object 303 Gang of Four started it all 307 Don't inherit – compose! 307 Pattern taxonomy 312 Creational patterns 313 Structural patterns 314 [ iii ] Table of Contents Behavioral patterns 315 Concurrency patterns 316 Criticism 318 Anti-patterns 319 Design principles 320 SOLID 321 Don't repeat yourself 322 KISS and YAGNI 322 Summary 323 Chapter 10: Singleton, Dependency Injection, Lazy Initialization, and Object Pool 324 Singleton 325 NewInstance 331 Lateral thinking 335 Dependency injection 339 From classes to interfaces 343 Using a factory method 346 Wrapping up 348 Lazy initialization 349 Using Spring 353 Object pool 355 Stock quote connection pool 357 Summary 363 Chapter 11: Factory Method, Abstract Factory, Prototype, and Builder 365 Factory method 365 Painter 370 Modernizing the factory method pattern 373 Abstract factory 375 Prototype 383 Cloning records 384 Cloning objects 388 Delphi idioms – Assign and AssignTo 391 Serialization 395 Builder 395 Idioms – Fluent interfaces 400 Summary 403 Chapter 12: Composite, Flyweight, Marker Interface, and Bridge 405 Composite 406 Child management 407 Flyweight 412 String interning 413 A practical example 415 Delphi idioms – comparers and hashers 419 [ iv ]