Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Arrow up icon
GO TO TOP
Learning D

You're reading from   Learning D Leverage the modern convenience and modelling power of the D programming language to develop software with native efficiency

Arrow left icon
Product type Paperback
Published in Nov 2015
Publisher
ISBN-13 9781783552481
Length 464 pages
Edition 1st Edition
Arrow right icon
Author (1):
Arrow left icon
Michael Parker Michael Parker
Author Profile Icon Michael Parker
Michael Parker
Arrow right icon
View More author details
Toc

Table of Contents (13) Chapters Close

Preface 1. How to Get a D in Programming 2. Building a Foundation with D Fundamentals FREE CHAPTER 3. Programming Objects the D Way 4. Running Code at Compile Time 5. Generic Programming Made Easy 6. Understanding Ranges 7. Composing Functional Pipelines with Algorithms and Ranges 8. Exploring the Wide World of D 9. Connecting D with C 10. Taking D Online 11. Taking D to the Next Level Index

Ranges in use


The key concept to understand ranges in the general case is that, unless they are infinite, they are consumable. In idiomatic usage, they aren't intended to be kept around, adding and removing elements to and from them as if they were some sort of container. A range is generally created only when needed, passed to an algorithm as input, then ultimately consumed, often at the end of a chain of algorithms. Even forward ranges and output ranges with their save and put primitives usually aren't intended to live beyond an algorithm.

That's not to say it's forbidden to keep a range around; some might even be designed for long life. For example, the random number generators in std.random are all ranges that are intended to be reused. However, idiomatic usage in D generally means lazy, fire-and-forget ranges that allow algorithms to operate on data from any source and minimize memory allocations.

For most programs, the need to deal with ranges directly should be rare; most code will...

lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image