-
-
Notifications
You must be signed in to change notification settings - Fork 51
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add extra guidance on mentored pair programming (#1133)
We want to specifically call out to volunteers that, unlike in other pair programming, they're not meant to write code _or_ say what code to write.
- Loading branch information
1 parent
59d51a8
commit 4b91324
Showing
4 changed files
with
78 additions
and
17 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
+++ | ||
title = 'Pair programming' | ||
description = 'Practice writing code and getting support' | ||
emoji = '👥' | ||
+++ | ||
|
||
Pair programming is working together with someone else to code a solution to a problem. | ||
|
||
## Why | ||
Pair programming is an excellent way to develop programming and communication skills. | ||
|
||
It can be easier to work through a problem when working with someone 1-to-1. | ||
|
||
Pair programming prepares our trainees for technical interviews when they'll code in front of other people. | ||
|
||
## How | ||
|
||
Choose your style: [mentored](./mentored/) or [driver/navigator](./driver-navigator/). Think about whether to pair with another learner or a mentor - both are useful, but they're different. | ||
|
||
Pick a piece of programming to do, find a buddy, and work on it together. |
22 changes: 22 additions & 0 deletions
22
org-cyf-guides/content/pair-programming/driver-navigator/index.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
+++ | ||
title = 'Driver/navigator pair programming' | ||
description = 'Taking turns writing code' | ||
emoji = '👥' | ||
weight = 3 | ||
+++ | ||
|
||
A common form of pair-programming has the pairs taking turns. One acts as the "driver" - actually using the keyboard. The other acts as the "navigator" - providing directions and support. | ||
|
||
This is different from [mentored pair programming](../mentored/) where the learner is doing most of the work, with the mentor is there to support and stretch. | ||
|
||
You can do driver/navigator pair programming regardless of the levels of the pairs. Two learners can do this. A learner can do this with a mentor. Both are useful. Lots of people do this at work as software engineers: this is not just for learning. | ||
|
||
If a learner is pairing with a mentor, they should still take turns. The learner will benefit from writing code. The learner will also benefit from seeing how the mentor writes code. Mentors will be able to help both by seeing how a learner writes code, and how they think/direct. | ||
|
||
## Resources | ||
|
||
[Our general pair programming guidance](../guidance/) | ||
|
||
[Tips for pair programming](https://www.csteachingtips.org/tips-pair-programming) | ||
|
||
[Guidance on pair programming for learning](https://teachtogether.tech/en/#s:classroom-pair) |
23 changes: 6 additions & 17 deletions
23
...-guides/content/pair-programming/index.md → ...ontent/pair-programming/guidance/index.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
+++ | ||
title = 'Mentored pair programming' | ||
description = 'Practice writing code and getting support' | ||
emoji = '👥' | ||
weight = 2 | ||
+++ | ||
|
||
We assign **mentored pair programming** as a coursework assignment throughout the course. | ||
|
||
This is different from [driver/navigator](../driver-navigator/) pair-programming where the pairs take turns. | ||
|
||
All of the standard [pair programming guidance](../guidance) applies - make sure you're familiar with it. | ||
|
||
**Before** a mentored pair programming session, learners should decide what they're going to pair on and share this with the volunteer, e.g. by sharing a link to a particular Codewars exercise, a particular piece of coursework, or some other problem. | ||
|
||
**During** mentored pair programming, the **learner** should: | ||
* **Explain** their thought process | ||
* **Break down** the problem | ||
* **Plan** what code to write | ||
* **Write** all of the code | ||
* **Check** that it works | ||
|
||
The **mentor** should: | ||
* **Ask questions** to get the trainee thinking. It's always better to _ask_ than tell. | ||
* Help the trainee think about breaking down the problem | ||
* Support the trainee as they write code | ||
* Help the trainee to debug their code | ||
* Stretch the trainee by bringing up edge cases or complications | ||
|
||
This is different from other forms of pair programming (e.g. [driver/navigator](../driver-navigator/)), where both people may be expected to write code, or people may take turns at different roles. This is because the goal is different: the goal is **teaching**. |