EECS 280 Tutorials
Setting up Visual Studio
Visual Studio is a feature-rich integrated development environment (IDE) that runs on Windows.
If you already have Visual Studio installed, skip to the Create a project section.
Prerequisites
Visual Studio runs on Windows only. There are no other prerequisites for Visual Studio.
This tutorial recommends command line tools. To install CLI tools, follow the Windows command line tools tutorial.
Next, we recommend our Command line interface (CLI) tutorial.
Pitfall: Make sure you have installed CLI tools for Windows before continuing.
Install
Install Visual Studio Community edition from Microsoft’s website.
Select “Desktop Development with C++” and make sure that the “Windows 10 SDK”, “Windows 11 SDK”, and “C++ AddressSanitizer” are selected. Click “Continue”. Reboot your computer when the installer prompts you.
Start Visual Studio. The first time, you’ll be asked about a few preferences.
The screenshots in the tutorial were created with Visual Studio Community 2022. Your version might be different.
Create a project
A Visual Studio project contains the files and information to build your software. In EECS 280, you’ll eventually create one Visual Studio project for each EECS 280 project.
Start Visual Studio. Create a new project. You can also use “File” > “New” > “Project”.
Select “Console App”. Click “Next”.
Set a project name, we’ll call our example project stats
. Pick a location where you’ll store your projects. Check “Place solution and project in the same directory. We recommend this in EECS 280 so that everyone has a one-level structure (stats/main.cpp
) instead of a two-level structure (stats/stats/main.cpp
). Click “Next”.
Pitfall: Avoid paths that contain spaces. Spaces cause problems with some command line tools.
Bad Example | Good Example |
---|---|
EECS 280/ |
eecs280/ |
EECS 280 Stats Project/ |
stats/ |
You can see the files created by Visual Studio in the File Explorer. Right-click stats
, select “Show in Finder”.
You can also see the files created by Visual Studio from the WSL command line. Notice that Visual Studio created .sln
, and vcxproj
files.
$ tree
.
├── stats.cpp
├── stats.sln
├── stats.vcxproj
├── stats.vcxproj.filters
└── stats.vcxproj.user
Rename main file
Rename the default stats.cpp
to main.cpp
. Your main filename may be different. Use Visual Studio to rename a file, not the command line or File Explorer.
Right-click stats.cpp
and select “Rename”. Change the file name.
Add new files
Visual Studio created main.cpp
by default. Skip this subsection your first time through the tutorial. You can come back to it.
Open your project folder by selecting File
> Open
> Project/Solution
, navigate to your project directory (stats
in this example) and open stats.sln
. An alternative is to double-click stats.sln
in the File Explorer.
Right-click “Source Files”, then select “Add” > “New Item”.
Select “Visual C++” and “C++ File”. Name your file, we’ll use stats.cpp
for this example. Click “Add”.
You should see your new file under “Source Files”.
Add existing files
If you have starter files, add them to your project directory. This example is from EECS 280 Project 1, but this tutorial doesn’t require understanding the files. Your URL or files might be different.
Pitfall: Make sure you’re in the directory containing your source code.
$ ls
main.cpp
stats.sln
...
Pro-tip: Copy/paste instructions for WSL.
We’ll use the WSL (Ubuntu) terminal to download, unpack, and move starter files into the directory that already contains main.cpp
. Your URL or folder might be different.
$ wget https://eecs280staff.github.io/stats/starter-files.tar.gz
$ tar -xvzf starter-files.tar.gz
$ mv starter-files/* .
$ rm -rf starter-files starter-files.tar.gz
You should see your new files in the src
subdirectory.
$ tree
.
├── Makefile
├── cats.csv
├── cats.out.correct
├── main.cpp
├── stats.sln
├── stats.vcxproj
├── stats.vcxproj.filters
├── stats.vcxproj.user
├── library.cpp
├── library.hpp
├── stats.hpp
├── stats_public_tests.cpp
├── stats_tests.cpp.starter
└── two_sample.cpp.starter
Right-click “Source Files”, then select “Add” > “Existing Item”.
Navigate to your project directory. Select your files by holding Control and clicking each one. Your specific files may not match the image below. Do not select any .sln
or .vcxproj
files. Click “Add”.
You will now see your files in the sidebar in the sidebar.
Rename files
If you need to rename any files, use Visual Studio, not the command line or File Explorer. In EECS 280, you’ll need to rename any files that end in .starter
.
Right-click a file and select “Rename”. Change the file name.
Compile and Run
A Visual Studio Build compiles one executable.
Exclude files from build
We need to avoid multiple main()
functions in the same build. Exclude files not needed to compile the main program. This often means excluding unit tests from the build.
In this example from EECS 280 Project 1, we need to exclude our unit tests from the build because they each contain a main()
function.
Right-click a file in the solution explorer (sidebar) and select “Properties”. Set “Excluded From Build” to “Yes”.
You can see a red symbol next to each excluded file.
“Build” -> “Build Solution”. See that the build output was successful.
Run
Click the “Local Windows Debugger” button. You should see your program run.
Sanitizers
Visual Studio provides an address sanitizer with bounds checking automatically with every debug build. You don’t need to do anything different!
Pitfall: When Visual Studio says “Press any key to continue”, press a key, do not close the window by clicking the X. Some memory checks run after you press any key.
Command-Line Arguments and Options
Skip this subsection your first time through the tutorial. You can come back to it.
Inputs to a program may be provided when it is initially run via command-line arguments or options. Here’s an example from EECS 280 Project 1:
$ ./two_sample.exe HCMST_ver_3.04.tsv q24_met_online 1 0 ppage
./two_sample.exe
is used to run the program- Each of
HCMST_ver_3.04.tsv
,q24_met_online
,1
,0
,ppage
are passed to it as arguments
The arguments above specify the name of a data file, coulumns, and filter values for the program to use.
Right-click the project in the Solution Explorer (stats
in this example). Select “Properties”.
Edit “Command Arguments” and click “OK”.
Input redirection
Skip this subsection for EECS 280 project 1.
If you’re unfamiliar with input redirection, first read the CLI tutorial section on input redirection.
Without input redirection, here’s how to type input in the Visual Studio command line. Notice that when we run, a window pops up that accepts user input.
To configure input redirection, right-click the project in the Solution Explorer (stats
in this example). Select “Properties”.
Edit “Command Arguments” and click “OK”.
Pitfall: With input redirection configured, Visual Studio will automatically close the terminal window, and you’ll miss seeing the output.
Set a breakpoint on the last line of main
to keep the output window open.
Debug
In this section, we’ll set a breakpoint, which pauses the debugger. Then, we’ll cover some of the options to continue execution.
Step Over Run one line of code, stepping over any function calls by running the whole function in one step.
Step Into Run one line of code, stepping into any function calls to execute them line-by-line.
Step Out Run the program until it returns from the current function (or until the next breakpoint).
Continue Run the program until the next breakpoint.
Example code
To get started, copy this example main.cpp
into your editor.
#include <iostream>
#include <vector>
using namespace std;
double sum (const vector<double> &data) {
double total = 0;
for (size_t i=0; i<data.size(); ++i) {
total += data[i];
}
return total;
}
int main() {
vector<double> data;
data.push_back(10);
data.push_back(20);
data.push_back(30);
cout << "sum(data) = " << sum(data) << endl;
}
Breakpoint
Select the file you want to debug. Set a breakpoint by clicking to the left of a line number. A breakpoint tells the program to pause.
Run
Run the debugger. The program pauses at the breakpoint. The indicator highlights the next line of code to be run.
Step over
Click “Step Over” a few times until you reach the highlighted line of code
Inspect
Hover over a variable to inspect its value. You can also see values in the Autos pane.
Step into
Click “Step Into”. The cursor enters the sum()
function.
Step out
Click “Step Out”. The sum()
function completes, and the program pauses again.
Continue
Press “Continue” to run the program to the next breakpoint, or the end, whichever comes first.
Troubleshooting
To reset Visual Studio project settings and starter files, first quit Visual Studio. Make a backup copy of your files, and then delete your project directory. Your project directory might be different.
/Users/awdeorio/src/eecs280
$ cp -a stats stats.bak # Backup
$ rm -rf stats # Delete
Visual Studio has a lot of settings. You can reset the entire user interface to the default settings by selecting “Tools” -> “Import” and Export Settings” -> “Reset all settings”. This is optional.
Acknowledgments
Original document written by Andrew DeOrio awdeorio@umich.edu.
This document is licensed under a Creative Commons Attribution-NonCommercial 4.0 License. You’re free to copy and share this document, but not to sell it. You may not share source code provided with this document.