Speakerline
Speakers
Proposals
Events
Tags
Edit a proposal
Adam Cuppy
Ahmed Omran
Alan Ridlehoover
Amit Zur
Andrew Mason
Andrew Nesbitt
Andy Andrea
Andy Croll
Asia Hoe
Avdi Grimm
Ben Greenberg
Bhavani Ravi
Brandon Carlson
Brittany Martin
Caleb Thompson
Caren Chang
Chiu-Ki Chan
Christine Seeman
Claudio Baccigalupo
Cody Norman
Devon Estes
Eileen Uchitelle
Emily Giurleo
Emily Samp
Enrico Grillo
Espartaco Palma
Fito von Zastrow
Frances Coronel
Hilary Stohs-Krause
Jalem Raj Rohit
Jemma Issroff
Jenny Shih
Jim Remsik
Joel Chippindale
Justin Searls
Katrina Owen
Kevin Murphy
Kudakwashe Paradzayi
Kylie Stradley
Maeve Revels
Maryann Bell
Matt Bee
Mayra Lucia Navarro
Molly Struve
Nadia Odunayo
Nickolas Means
Noah Gibbs
Olivier Lacan
Ramón Huidobro
Richard Schneeman
Rizky Ariestiyansyah
Saron Yitbarek
Sean Moran-Richards
Shem Magnezi
Srushith Repakula
Stefanni Brasil
Stephanie Minn
Sweta Sanghavi
Syed Faraaz Ahmad
Tekin Suleyman
Thomas Carr
Tom Stuart
Ufuk Kayserilioglu
Valentino Stoll
Victoria Gonda
Vladimir Dementyev
Title
Tags (comma-separated, max 3)
Body
### Description “I’ve done ‘pairing,’ but it wasn’t for me: I like my editor. I like my space. I don’t like to talk all the time… you know.” We’ve all had our reasons. And, I will admit that it works for some and not for others, and it works better in some situations and not in others. But, what if my “bad experience” is a fluke of “how” it’s being done? What should you expect from a good pair? How do you handle timezones? System configurations? And, what tools should you use to make the experience optimal? There’s a lot of opinion about pair programming, but we’re going go over what to expect from pairing, and when it’s the “right time” to use it. ### Notes The function of this talk is not a case in favor of pair-programming (although that may be a take away). The structure of the talk is to address patterns for effective pair programming; there is an effective “how.” The talk is structured into two parts: **The What’s Its** * Pair programming involves 1 computer, 2 monitors, 2 sets of peripherals * Pair programming and “parallel programming” are two different things * Positive benefits: code quality; knowledge sharing; focus, accountability; redundancy * Downsides (if done poorly): short term cost; larger mental/social commitment; “exhausting” **How’s Its** * Methods: Driver/Navigator, Ping-Pong Pairing * Tools: VIM/TMUX, git pair and git duet, Nitrious.io, Screenhero * Core tenants: over communicate, simplify, share, empathize. ### Pitch Our consultancy is advised by Kent Beck, so the topic is near to us. We’ve discussed on occasions the merits of pair programming. Kent told us, “You know, most people read the last half of my book on eXtreme Programming – the part about the tools – and they get attached to pair programming, TDD and iterations, but miss the reasons why you do it, at all.” Not too long ago, we decided to take a step back and ask “why are we doing it?” and found that certain aspects of pairing, like TDD, are important, and other’s aren’t. We’ve experimented with full time pairing, soloing and everything in between. We’ve tested rigid schedules and total freedom. We’ve worked across time zones, local and remote and VIM/TMUX against Screenhero, Skype and Google Hangout. We haven’t tried everything, but we’ve tried a lot of things. This talk is not going to force the issue, but introduce the methodologies we’ve used to maximize the value of pair programming. It’s a very balanced approach to the subject.
Back to Speaker Directory