Howdy!
These files are a collection of everything I feel is necessary to get started in C++.
My recommended reading order is:
- variables
- control
- arrays
- operators
- io
- functions
- memory
- structsandclasses
This is a lot, yes. I'm basically throwing all of CSCE 121 at you and expecting you to work on the first homework from CSCE 221. If the 'homework' seems too hard, try doing your old ENGR 102 assignments. If you don't still have them, I can get them pretty easily.
If something doesn't make sense, seems very vague, or you have some other problem please let me know ASAP so I can work to improve these files. I am available all break if you want to talk or need any help at all. I am an ENGR 102 PT, it takes a lot to annoy me so please ask questions. Feel free to work together, AggieSat is a team project and no one should have to go it alone.
I, personally, use VSCode (not Visual Studio) for developing in C++.
It has useful extensions for interacting with WSL (see below) and code completion/syntax highlighting.
Some extensions you will find helpful:
- Intellicode
- C/C++ Extension Pack
- WSL
Once you've installed the WSL extension and activated WSL,
press the green button in the bottom left of VSCode and select New WSL Window
to open VSCode in WSL mode.
If you're using Windows, activate WSL.
https://learn.microsoft.com/en-us/windows/wsl/install
If you're on a Mac, you can just use the terminal.
You (probably) don't have a gui to work with in Linux.
We operate primarily in the terminal at AggieSat when working with our hardware and the satellite won't use a gui to operate itself.
Some useful commands are:
- cd [directory name] : change directory to [directory name]
-
- cd .. : goes up one directory in the tree
-
- cd ~ : goes to the home directory
-
- cd . : goes to the current directory
-
- cd - : goes to the previous directory
- ls : list the files in the current directory
- pwd : print the working (current) directory
- mkdir [directory name] : makes a directory called [directory name]
- rm [file name] : removes a file called [file name]
- sudo [command] : (super user do) runs the command at the highest level
Once you have access to a linux shell, install git by running sudo apt install git
in the terminal.
Download this git repository by running git clone https://github.com/1Pokeman1/AggieSatHW.git
in the directory you want it.
For the purposes of these notes, we will use g++.
To install g++ run sudo apt install g++
in the terminal.
To compile with g++ run g++ [file name.cpp]
in the terminal.
This will result in the creation of a file called a.out
which can be run by typing ./a.out
in the terminal.
I recommend running g++ with the -std=c++17
argument, this will make it less mad at you.
If you want the compiled program to be called something else, use the -o [file name]
argument.
The following arguments may be added to increase the number of warnings the compiler will check for.
-Wall
: adds a bunch of warnings. is actually a compilation of like 20+ other flags.-Wextra
: everything-Wall
doesn't do.-pedantic
: will yell at you for code style.-Werror
: turns warnings into errors which prevent compilation
Ideally your g++ command should look something like g++ -Wall -Wextra -pedantic -std=c++17 [input file name(s)] -o [output file name]
,
but g++ -std=c++17 [input file name(s)] -o [output file name]
is fine.
In the terminal, run ./[output file name]
Valgrind is a program that watches the memory usage of a program as it runs and reports if it finds any leaks.
Install valgrind by running sudo apt install valgrind
in the terminal.
Say we have a program called a.out
, we can run valgrind on it by running valgrind ./a.out
in the terminal.
Install make by running sudo apt install make
in the terminal.
I've included a makefile with "homework" 1. This will allow you to compile by just running make
in the terminal.
You are welcome to lookup how makefiles work. I'm not going to cover them until we get to more complex stuff.