Добавление новых файлов в проект в среде разработки Visual Studio 2008

Для добавления новых файлов в проект новых файлов в проект необходимо вызвать контекстное меню над именем проекта в «Проводнике решений» (Solution Explorer) (см. рисунок 13.1) и далее выбрать раскрывающийся пункт «Добавить» (Add). В нем нас на текущий момент будут интересовать два подпункта “New Item …” (Новый объект) и “Exiting Item …” (Существующий объект). Первый создает новый файл, одного из предложенных типов, а второй добавляет к проекту уже существующий. Диалоговое окно с вариантами доступных для создания файлов представлено на рисунке 13.2.

Результат добавления файлов в проект представлен на рисунке 13.3. Теперь достаточно воспользоваться директивой #include для использования функций, констант и типов данных, располагающихся в новых файлах.

Добавление новых файлов в проект в среде разработки Visual Studio 2008 - student2.ru

Рисунок 13.1 – Добавление нового файла в проект

Добавление новых файлов в проект в среде разработки Visual Studio 2008 - student2.ru

Рисунок 13.2 – Диалоговое окно выбора типа добавляемого файла

Добавление новых файлов в проект в среде разработки Visual Studio 2008 - student2.ru

Рисунок 13.3 – Результат добавления новых файлов в проект

Пример работы с многофайловыми проектами

Разберем работу с многофайловыми проектами на примере задачи из предыдущей лабораторной работы.

Пример 13.1 Нахождение расстояния между точками

Задание. Написать программу, которая находит расстояние между двумя точками. Координаты могут задаваться как в декартовой, так и в полярной системе координат. Предусмотреть функции перевода из декартовой системы в полярную и обратно.

Алгоритм решения:

- Задать или ввести с клавиатуры координаты точек.

- Для пары точек определить расстояние по одной из формул:

o для декартовой системы: Добавление новых файлов в проект в среде разработки Visual Studio 2008 - student2.ru

o для полярной системы: Добавление новых файлов в проект в среде разработки Visual Studio 2008 - student2.ru

- Вывести результаты на экран.

Определение требуемых типов данных.

Для удобства хранения информации о координате точки в одной из систем координат удобно воспользоваться структурами, хранящими пары координат одной и той же точки. Для простоты назовем их cartesian для декартовой, и polar для полярной системы координат.

Разбиение на подзадачи.

В результате описанного алгоритма и задания определяем спецификации нужных нам функций. Для удобства использования воспользуемся перегрузкой:

1. double len(cartesian a, cartesian b) – принимает две координаты в декартовой системе и возвращает длину.

2. double len(polar a, polar b) – принимает две координаты в полярной системе и возвращает длину.

3. double len(cartesian a, polar b) – принимает первую координату в декартовой системе, а вторую в полярной, и возвращает длину.

4. double len(polar a, cartesian b) – принимает первую координату в полярной системе, а вторую в декартовой, и возвращает длину.

5. polar cartesian_to_polar(cartesian x) – переводит координаты точки из в декартовой системы в полярную.

6. cartesian polar_to_cartesian(polar x) – переводит координаты точки из в полярной системы в декартову.

Разбиение на модули.

Исходя из логики работы программы, а также, возможного дальнейшего применения полученных результатов естественным будет разбить ее на два файла: PRG-Lab13.cpp – содержащий точку входа в программу, а также основные вызовы функции и взаимодействие с пользователем; points.cpp – содержащий реализации вышеперечисленных функций; а также points.h – содержащий интерфейсы данных функций и типы данных, и служащий для подключения возможностей работы с точками в различных системах координат.

Файл points.h

// points.h : Содержит определения основных типов и прототипы функций.

//

#ifndef POINTS_H

#define POINTS_H

//Объявления типов

//Точка в декартовой системе координат

struct cartesian{

double x, y;

};

//Точка в полярной системе координат

struct polar{

double r, pi;

};

//Прототипы функций

double len(polar a, polar b);

double len(cartesian a, cartesian b);

double len(cartesian a, polar b);

double len(polar a, cartesian b);

polar cartesian_to_polar(cartesian x);

cartesian polar_to_cartesian(polar x);

#endif

Файл points.cpp

Примечание. Обратите внимание на повторное использование вызовов уже существующих функций. Данная техника позволяет добиться быстрого и удобного внесения корректив (хотя и за счет несущественной потери в производительности). Например, при наличии ошибки, скажем, при неверно запрограммированной формуле, ее достаточно исправить лишь в одном месте, а не искать по всему тексту модуля.

// points.cpp : Содержит определения функций

//

#include "stdafx.h"

#include "points.h"

#include <math.h>

double len(polar a, polar b)

{

return sqrt( pow(a.r, 2) + pow(b.r, 2) - 2*a.r*b.r*cos(a.pi - b.pi) );

}

double len(cartesian a, cartesian b)

{

return sqrt( pow(a.x - b.x, 2) + pow(a.y - b.y, 2) );

}

double len(cartesian a, polar b)

{

cartesian c;

c = polar_to_cartesian(b);

return len(a, c);

}

double len(polar a, cartesian b)

{

return len(b, a);

}

polar cartesian_to_polar(cartesian x)

{

polar y;

y.r = sqrt(pow(x.x, 2) + pow(x.x, 2));

if (y.r == 0)

y.pi = 0;

else

y.pi = asin(x.y/y.r);

return y;

}

cartesian polar_to_cartesian(polar x)

{

cartesian y;

y.x = x.r*cos(x.pi);

y.y = x.r*sin(x.pi);

return y;

}

Файл PRG-Lab13.cpp

// PRG-Lab13.cpp : Основной файл проекта, содержит точку входа в программу

//

#include "stdafx.h"

#include <iostream>

#include "points.h"

using namespace std;

void main(int argc, char* argv[])

{

setlocale(LC_ALL, "Russian");

const double PI = 3.14159;

cartesian a = {3, 0},

b = {1, 1};

polar c = {1.41, PI/4},

d = {3.1, 0.95};

//вызовы перегруженных функций

//для точек в различных системах координат

//декартова - декартова

cout << len(a, b) << endl;

//полярная - полярная

cout << len(c, d) << endl;

//декартова - полярная

cout << len(a, d) << endl;

//полярная - декартова

cout << len(c, b) << endl;

}

Таким образом мы получили собственную мини библиотеку, которую можно расширять в дальнейшем и использовать в других проектах.

Контрольные вопросы

1. В чем отличие многофайлового проекта?

2. Как добавить новый файл в проект?

3. Что такое модуль?

4. Для чего нужно разбиение на модули?

5. Для чего применяются заголовочные файлы?

6. Что размещается в заголовочных файлах, а что выносится в тело модуля?

Задание

1. Создать новый проект.

2. Добавить к проекту файл исходным кодом (.h и .cpp).

3. Вынести в отдельный модуль функции и типы данных.

4. Написать программу в соответствии с вариантом задания из пункта 5, задав начальные значения при объявлении переменных.

5. Отладить и протестировать программу.

6. Создать новый проект.

7. Подключить модуль из предыдущего задания в новый проект.

8. Написать программу в соответствии с вариантом задания из пункта 5, введя начальные значения переменных с клавиатуры.

9. Отладить и протестировать программу.

10. Оформить отчёт.

Варианты заданий

1. Определить функцию, возвращающую количество дней до конца месяца. Выполнить перегрузку функции для следующих типов параметров:

1.1. Структура «дата» (год, месяц, день).

1.2. Три целочисленных параметра: год, месяц, день.

1.3. Два целочисленных параметра: месяц, день (считать передаваемые числа датой текущего года).

2. Определить функцию, возвращающую НОК нескольких чисел. Выполнить перегрузку функции для следующих типов параметров:

2.1. Два параметра типа int.

2.2. Два параметра типа long.

2.3. Два параметра типа float.

2.4. Два параметра типа double.

3. Определить функцию, находящую максимальный элемент массива. Выполнить перегрузку функции для следующих типов параметров:

3.1. Одномерный массив типа int размерностью N.

3.2. Одномерный массив типа float размерностью N.

3.3. Одномерный массив типа double размерностью N.

4. Определить функцию, возвращающую минимальное из нескольких чисел. Выполнить перегрузку функции для следующих типов параметров:

4.1. Три параметра типа int.

4.2. Четыре параметра типа int.

4.3. Три параметра типа float.

4.4. Два параметра типа double.

5. Определить функцию, возвращающую количество недель с начала года. Выполнить перегрузку функции для следующих типов параметров:

5.1. Структура «дата» (год, месяц, день).

5.2. Три целочисленных параметра: год, месяц, день.

5.3. Два целочисленных параметра: месяц, день (считать передаваемые числа датой текущего года).

6. Определить функцию, возвращающую количество недель до конца года. Выполнить перегрузку функции для следующих типов параметров:

6.1. Структура «дата» (год, месяц, день).

6.2. Три целочисленных параметра: год, месяц, день.

6.3. Два целочисленных параметра: месяц, день (считать передаваемые числа датой текущего года).

7. Определить функцию, возвращающую НОД нескольких чисел. Выполнить перегрузку функции для следующих типов параметров:

7.1. Два параметра типа int.

7.2. Два параметра типа long.

7.3. Два параметра типа float.

7.4. Два параметра типа double.

8. Определить функцию, возвращающую количество минут до окончания суток. Выполнить перегрузку функции для следующих типов параметров:

8.1. Структура «время» (часы, минуты, секунды).

8.2. Три целочисленных параметра: часы, минуты, секунды.

8.3. Два целочисленных параметра: часы, минуты.

9. Определить функцию, возвращающую предыдущую минуту. Выполнить перегрузку функции для следующих типов параметров:

9.1. Структура «время» (часы, минуты, секунды).

9.2. Три целочисленных параметра: часы, минуты, секунды.

9.3. Два целочисленных параметра: часы, минуты.

10. Определить функцию, находящую сумму элементов массива. Выполнить перегрузку функции для следующих типов параметров:

10.1. Одномерный массив типа int размерностью N.

10.2. Одномерный массив типа float размерностью N.

10.3. Одномерный массив типа double размерностью N.

11. Определить функцию, проверяющую верна ли дата. Выполнить перегрузку функции для следующих типов параметров:

11.1. Структура «дата» (год, месяц, день).

11.2. Три целочисленных параметра: год, месяц, день.

11.3. Два целочисленных параметра: месяц, день (считать передаваемые числа датой текущего года).

12. Определить функцию, возвращающую расстояние между точками числа. Выполнить перегрузку функции для следующих типов параметров:

12.1. Два параметра типа структура «точка» (координаты x, y).

12.2. Четыре параметра типа float.

12.3. Четыре параметра типа double.

13. Определить функцию, возвращающую следующую минуту. Выполнить перегрузку функции для следующих типов параметров:

13.1. Структура «время» (часы, минуты, секунды).

13.2. Три целочисленных параметра: часы, минуты, секунды.

13.3. Два целочисленных параметра: часы, минуты.

14. Определить функцию, находящую произведение ненулевых элементов массива. Выполнить перегрузку функции для следующих типов параметров:

14.1. Одномерный массив типа int размерностью N.

14.2. Одномерный массив типа float размерностью N.

14.3. Одномерный массив типа double размерностью N.

15. Определить функцию, возвращающую прошедшее время в минутах (считать, что разница между передаваемыми значениями не превышает 24 часа). Выполнить перегрузку функции для следующих типов параметров:

15.1. Два параметра типа структура «время» (часы, минуты, секунды).

15.2. Шесть целочисленных параметра: часы, минуты, секунды.

15.3. Четыре целочисленных параметра: часы, минуты.

16. Определить функцию, возвращающую минимальное из нескольких чисел. Выполнить перегрузку функции для следующих типов параметров:

16.1. Два параметра типа int.

16.2. Три параметра типа int.

16.3. Два параметра типа float.

16.4. Три параметра типа float.

16.5. Три параметра типа double.

17. Определить функцию, возвращающую количество дней с начала года. Выполнить перегрузку функции для следующих типов параметров:

17.1. Структура «дата» (год, месяц, день).

17.2. Три целочисленных параметра: год, месяц, день.

17.3. Два целочисленных параметра: месяц, день (считать передаваемые числа датой текущего года).

18. Определить функцию, возвращающую n-ю степень числа x. Выполнить перегрузку функции для следующих типов параметров:

18.1. Два параметра: x и n – оба типа int.

18.2. Два параметра: x и n – оба типа float.

18.3. Два параметра: x – типа float, и n – типа int.

19. Определить функцию, находящую минимальный элемент массива. Выполнить перегрузку функции для следующих типов параметров:

19.1. Одномерный массив типа int размерностью N.

19.2. Одномерный массив типа float размерностью N.

19.3. Одномерный массив типа double размерностью N.

20. Определить функцию, возвращающую количество минут с начала суток. Выполнить перегрузку функции для следующих типов параметров:

20.1. Структура «время» (часы, минуты, секунды).

20.2. Три целочисленных параметра: часы, минуты, секунды.

20.3. Два целочисленных параметра: часы, минуты.

21. Определить функцию, возвращающую среднеарифметическое нескольких чисел. Выполнить перегрузку функции для следующих типов параметров:

21.1. Два параметра типа int.

21.2. Три параметра типа int.

21.3. Три параметра типа float.

21.4. Два параметра типа double.

22. Определить функцию, возвращающую день недели (иметь в виду, что 1 января 1-го года нашей эры было понедельником). Выполнить перегрузку функции для следующих типов параметров:

22.1. Структура «дата» (год, месяц, день).

22.2. Три целочисленных параметра: год, месяц, день.

22.3. Два целочисленных параметра: месяц, день (считать передаваемые числа датой текущего года).

23. Определить функцию, находящую среднеарифметическое элементов массива. Выполнить перегрузку функции для следующих типов параметров:

23.1. Одномерный массив типа int размерностью N.

23.2. Одномерный массив типа float размерностью N.

23.3. Одномерный массив типа double размерностью N.

24. Определить функцию, возвращающую максимальное из нескольких чисел. Выполнить перегрузку функции для следующих типов параметров:

24.1. Два параметра типа int.

24.2. Три параметра типа int.

24.3. Два параметра типа float.

24.4. Три параметра типа double.

25. Определить функцию, возвращающую количество дней до конца года. Выполнить перегрузку функции для следующих типов параметров:

25.1. Структура «дата» (год, месяц, день).

25.2. Три целочисленных параметра: год, месяц, день.

25.3. Два целочисленных параметра: месяц, день (считать передаваемые числа датой текущего года).

Содержание отчета

1. Титульный лист.

2. Наименование и цель работы.

3. Краткое теоретическое описание.

4. Задание на лабораторную работу.

5. Схема алгоритма.

6. Листинг программы.

7. Результаты выполнения программы.

Наши рекомендации