DLL files are dynamic linked library files written and controlled through the C++ programming language. DLLs simplify the process of sharing and storing code. This wikiHow teaches you how to create a DLL file using Visual Studio, Windows applications, or Visual Studio for Mac. Make sure you check the “Desktop Development with C++” option in the program installation process. If you already have a Visual Studio program, but don't check the box for that option, you'll need to run the installation file again to make sure the box can be checked.
Step
data:image/s3,"s3://crabby-images/c1867/c186739201e4602b8e2dcc6c390bcae235d61649" alt="11227960 1 11227960 1"
Step 1. Open Visual Studio
You can find this program in the "Start" menu or in the "Applications" folder. Because the DLL file is an information library, it is a "chunk" of the project and usually requires a companion application to be accessed.
- You can download Visual Studio for Windows at this site:
- Visual Studio for Mac can be downloaded here:
- This wikiHow uses code provided by Microsoft to explain how to create a DLL file.
data:image/s3,"s3://crabby-images/15ad8/15ad883fdc388937f84808041845440f686f065c" alt="11227960 2 11227960 2"
Step 2. Click File
This tab is at the top of the project area (Windows) or at the top of the screen (Mac).
data:image/s3,"s3://crabby-images/ae802/ae802531ee5f46ad34b040a79fb066d4b5cef386" alt="11227960 3 11227960 3"
Step 3. Click New and Projects.
The “Create a New Project” dialog box will be displayed.
data:image/s3,"s3://crabby-images/ad94f/ad94f8c15193a9b56931d7d3318905664cdf0eca" alt="11227960 4 11227960 4"
Step 4. Specify the options for the “Language”, “Platform”, and “Project Type” aspects
These aspects will filter the project templates that are displayed.
Click " Language ” to display the drop-down menu and click “ C++ ”.
data:image/s3,"s3://crabby-images/76ab2/76ab2f7a0d6f4a757e3c04bbc511bbf75c91ca98" alt="11227960 5 11227960 5"
Step 5. Click “Platforms ” to display the drop-down menu and click “ Windows”.
data:image/s3,"s3://crabby-images/8e389/8e389cec0ca316b47d05efb78d5ce8b2b2896d10" alt="11227960 6 11227960 6"
Step 6. Click “Project Type ” to display the drop-down menu and select “ Libraries.
data:image/s3,"s3://crabby-images/14c82/14c82837a31c77a657b30c4d0d94308215b147eb" alt="11227960 7 11227960 7"
Step 7. Click Dynamic-link Library (DLL)
Options will be marked in blue. Click " Next " to continue.
data:image/s3,"s3://crabby-images/42470/42470fc331782ab1593346a479a02f24892ea351" alt="11227960 8 11227960 8"
Step 8. Type the project name in the “Name Box” field
For example, you can type “MathLibrary” in the column as an example name.
data:image/s3,"s3://crabby-images/17100/1710085a8e19efc0472648aa0876205d5dd773ca" alt="11227960 9 11227960 9"
Step 9. Click Create
A DLL project will be created.
data:image/s3,"s3://crabby-images/adc90/adc9039444d75a62ea17c12c8323ab805f96eba5" alt="11227960 10 11227960 10"
Step 10. Add a header file to the DLL project
You can add it by clicking “Add New Item” from “Project” on the menu bar.
- Choose " Visual C++ ” from the menu on the left side of the dialog box.
- Choose " File headers (.h) ” from the middle of the dialog box.
- Type a name, for example, “MathLibrary.h” into the name field under the menu options.
- Click " Add ” to create an empty header file.
data:image/s3,"s3://crabby-images/0b6f0/0b6f0021166951b9692c1b1a26d5c6889333b099" alt="11227960 11 11227960 11"
Step 11. Type the following code into the blank header file
// MathLibrary.h - Contains declarations of math functions #pragma once #ifdef MATHLIBRARY_EXPORTS #define MATHLIBRARY_API _declspec(dllexport) #else #define MATHLIBRARY_API _declspec(dllimport) #endif // The Fibonacci recurrence relation F describes a sequence F // where n) is { n = 0, a // { n = 1, b // { n > 1, F(n-2) + F(n-1) // for some initial integral values a and b. // If the sequence is initialized F(0) = 1, F(1) = 1, // then this relation produces the well-known Fibonacci // sequence: 1, 1, 2, 3, 5, 8, 13, 21, 34, … // Initialize a Fibonacci relation sequence // such that F(0) = a, F(1) = b. // This function must be called before any other function. extern "C" MATHLIBRARY_API void fibonacci_init(const unsigned long long a, const unsigned long long b); // Produce the next value in the sequence. // Returns true on success and updates current value and index; // false on overflow, leaves current value and index unchanged. extern "C" MATHLIBRARY_API bool fibonacci_next(); // Get the current value in the sequence. extern "C" MATHLIBRARY_API unsigned long long fibonacci_current(); // Get the position of the current value in the sequence. extern "C" MATHLIBRARY_API unsigned fibonacci_index();
data:image/s3,"s3://crabby-images/1d789/1d7892c59a70a66438cd66981451dcdd9521f9bf" alt="11227960 12 11227960 12"
Step 12. Add the CPP file to the DLL project
You can add it by clicking “Add New Item” from “Project” on the menu bar.
- Select “Visual C++” from the menu on the left side of the dialog box.
- Select “C++ File (.cpp)” from the center of the dialog box.
- Type the name “MathLibrary.cpp” into the name field under the menu options.
- Click “Add” to create an empty file.
data:image/s3,"s3://crabby-images/63299/6329950717edeb86bdd6e1663a380d8972b46016" alt="11227960 13 11227960 13"
Step 13. Type the following code into the blank file
// MathLibrary.cpp: Defines the exported functions for the DLL. #include "stdafx.h" // use pch.h in Visual Studio 2019 #include #include #include "MathLibrary.h" // DLL internal state variables: static unsigned long long previous_; // Previous value, if any static unsigned long long current_; // Current sequence value static unsigned index_; // Current seq. position // Initialize a Fibonacci relation sequence // such that F(0) = a, F(1) = b. // This function must be called before any other function. void fibonacci_init(const unsigned long long a, const unsigned long long b) { index_ = 0; current_ = a; previous_ = b; // see special case when initialized } // Produce the next value in the sequence. // Returns true on success, false on overflow. bool fibonacci_next() { // check to see if we'd overflow result or position if ((ULLONG_MAX - previous_ < current_) || (UINT_MAX == index_)) { return false; } // Special case when index == 0, just return b value if (index_ > 0) { // otherwise, calculate next sequence value previous_ += current_; } std::swap(current_, previous_); ++index_; return true; } // Get the current value in the sequence. unsigned long long fibonacci_current() { return current_; } // Get the current index position in the sequence. unsigned fibonacci_index() { return index_; }
data:image/s3,"s3://crabby-images/4c15e/4c15e169a4fa0661a3d1c3ce8dfb993fe142bb04" alt="11227960 14 11227960 14"
Step 14. Click Build on the menu bar
This option is at the top of the project area (Windows) or at the top of the screen (Mac).
data:image/s3,"s3://crabby-images/75b3c/75b3c5d8d25d20652a3c0bef2bc77448573f9daa" alt="11227960 15 11227960 15"
Step 15. Click Build Solution
Once the option is clicked, you can see text like this:
1>------ Build started: Project: MathLibrary, Configuration: Debug Win32 ------ 1>MathLibrary.cpp 1>dllmain.cpp 1>Generating Code… 1> Creating library C:\Users\username \Source\Repos\MathLibrary\Debug\MathLibrary.lib and object C:\Users\username\Source\Repos\MathLibrary\Debug\MathLibrary.exp 1>MathLibrary.vcxproj -> C:\Users\username\Source\Repos\ MathLibrary\Debug\MathLibrary.dll 1>MathLibrary.vcxproj -> C:\Users\username\Source\Repos\MathLibrary\Debug\MathLibrary.pdb (Partial PDB) ========== Build: 1 succeeded, 0 failed, 0 up-to-date, 0 skipped ==========