CppCon 2018: Richard Powell “How to Argue(ment)'

preview_player
Показать описание


How many different ways are there to pass an argument? Why do we have so many? Which way should you be using? What does it mean when you use the wrong one?

A function declaration is like the thesis statement in an essay. It should communicate both for the caller and the callee it's purpose, semantics, and side-effects. We often think this communication is in the form of comments, but a function's arguments also convey this information.

This talk will catalog many the different ways to pass arguments. We will then explore which ones are redundant or nonsensical, and give meaning to the ones that remain. We will end with recommendations what types to use to express your intent, and empower you with fundamentals to write clearer function definitions.

Richard Powell, Audio Software Engineer

I started using C++ 10 years ago to write a psychoacoustic audio encoder/decoder and have continued to explore how to make software that unlocks the potential of hardware to bring amazing applications to life. I graduated from UC Berkeley with a BS in Electrical Engineering and Computer Science, and worked throughout the Bay Area for the past 15 years. I enjoy teaching and learning about C++ and programming.


*-----*
*--*
*-----*
Рекомендации по теме
Комментарии
Автор

I love this, because the beginning shows "How many basic ways does it appear you can pass something to a function?" and the answer is of course: "42". But like 10 dimensions collapsing down to 4 when we do the math, these also collapse down into a much smaller number that "make sense under normal programming conditions". Some of the ones that evaporate away are just silly, and some might come up once in a while in template meta-programming, but I am not upset at C++ or this presentation that it starts out at a higher number due to orthogonality. "You can pick your friends, you can pick your nose, but you can't pick your friend's nose."

jvsnyc
Автор

I definitely don't agree on raw pointer vs optional, for me raw pointers are definitely not good as it can express several different things, we can use it as another way of referencing a value, as a way to store an address of a dynamic allocation or for an optional value, as an iterator, as a sub collection or even a combination of those, pointers does not express the intent of the dev, optional does. And if you want to have an optional ref, just use std::optional<std::reference_wrapper<T>>, you can even do an alias like template <typename T> using optional_ref = for easier use. It is really important that your code reflect your intentions without even needing any comments. Don't use {} to express a null optional, use std::nullopt instead.
How many times I've worked with a C library in C++ not knowing how will this library will do with the pointer I give it, how many time do I had to save. Ban raw pointers, really. It might be easier to use, but it's not good for expressivness and therefore for your code maintenance.

stera
Автор

I've been having those questions long time ago. Thanks for this great talk!

younghsiang
Автор

25m you could use an though I personally would have a using alias to tidy the name

parnmatt
Автор

The pro-optional people hadn't mentioned one thing, how many languages have optional or nullable types in them now. Just in actual code at work, I've seen them in C#, Java and Swift in recent days, I believe also Scala and Kotlin. They don't all work exactly the same way, but I would say that the concept of Optional/nullable is pretty standard in most modern languages right now. So could readability to people who do indeed know C++ but often work in other languages as well be a +1 for optional?

jvsnyc
Автор

You can also pass an std::nullopt to a function taking an optional. I'm curious if when passing an empty initializer list if it gets implicitly converted to an std::nullopt.

warrenbuckley
Автор

Naming functions correctly is one important aspect of "Clean Code" - described in a book by Robert C. Martin (aka Uncle Bob). Making sure that functions do just one thing (otherwise they "cheat"), is another aspect of the same. I really love that you spread this wisdom using your own words.
BTW. All object-oriented programmers, PLEASE read this book! You will not regret that!

WiktorWandachowicz
Автор

Did you miss Pass by Forwarding-reference?

connorhorman
Автор

Never as an output parameter. But void*, std::size

connorhorman
Автор

C has only one way. Pass by value. Pointers are values. Isn't it ironic that the very features C++ needs to efficiently implement value semantics confuse the language with reference semantics and a hierarchy of value types that clutter function signatures?

p