Форум программистов, компьютерный форум CyberForum.ru

Классы. Не возвращает найденный объект. - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Работа содержит задачи, которые сводятся к нахождению суммы некоторого количества слагаемых http://www.cyberforum.ru/cpp-beginners/thread410015.html
1) Краткое теоретическое введение. Работа содержит задачи, которые сводятся к нахождению суммы некоторого количества слагаемых http://s61.***********/i171/1112/65/918da2500f14.jpg при различных значениях параметра суммирования х. Каждое слагаемое суммы зависит от параметра х и номера n, определяющего место этого слагаемого в сумме. Обычно формула общего члена суммы принадлежит к одному из...
C++ Проверка существования структуры Гугл ничего не дал так, что думаю будет многим полезно. Язык си, как проверить существует ли структура по данному адресу (была ли она задана)? В других языках есть try/catche на си вроде нет, только на си++. http://www.cyberforum.ru/cpp-beginners/thread410014.html
C++ Вычислить сумму ряда
.Вычислить сумму ряда \sum_{k=o }^{\propto }\left(-1{k}^{} \right)\frac{x{}^{2k}}{(2k)!} с точностью до 10 в -5 степени.Построить таблицу для х=0;0.1;0.2....0.9;1;0.Проверить значения по функции cos(х)
Поразрядная сортировка C++
Доброе время суток, написал программу поразрядной сортировки по определенному критерию должно сортировать, проблем в логике вроде бы не должно быть, но вот проблема в функции yy в том что не хватает выделения памяти для mask. даже при присвоение типа unsigned long long выходит за предел . Подскажите в чем причина и как с ней бороться #include <iostream> #include <algorithm> #include <vector>...
C++ сумма диагоналей??? http://www.cyberforum.ru/cpp-beginners/thread409956.html
Вот в чем вопрос! Вроде все правильно, но сумму неправильно вычисляет, а именно нужно: Найти максимальную, из всех сумм диагоналей, параллельных главной! #include <iostream> #include <iomanip> #include <cmath> using namespace std; // Прототип для ввода двумерного массива int** inputm (int n); // Прототип для вывода двумерного массива void outputm (int** a, int n);
C++ Разработать алгоритм обработки двумерного массива Разработать алгоритм обработки двумерного массива размера n*m. Числа m и n, а также элементы массива взять из файла. Необходимо каждый элемент массива увеличить на сумму элементов его строки. результат записать в другой файл. пожалуйста помогите очень нужно!! подробнее

Показать сообщение отдельно
res
56 / 9 / 1
Регистрация: 05.04.2010
Сообщений: 143
17.12.2011, 22:25  [ТС]     Классы. Не возвращает найденный объект.
Цитата Сообщение от BRcr Посмотреть сообщение
Вы создали вектор указателей на ваш класс. Пустой вектор, в нем ни фига нет - и тут же обращаетесь к его элементам, коих не существует. Это ошибка.
Вектор не пуст
C++
1
2
3
4
        
        Worker w(1); // объявляем ID рабочего
        w.AddMoneys(5000);
        w.Accept(); // записываем в вектор
проблема с этим уже решена, но вот появилась другая.
Сейчас отпишусь после тестов

Добавлено через 11 минут
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
// преопределение 
class Worker;
 
// база данных рабочих
struct WorkersDB
{
    static vector <Worker*> cache;
};
 
// управление рабочими
class Worker
{
public:
 
    Worker() {} // finder
    Worker(int workerId) : itsWorkerId(workerId) { itsMoneysCount = 0;}
    ~Worker() {}
 
    int GetWorkerId() { return itsWorkerId; }
    void AddMoneys(int moneysCount) { itsMoneysCount +=moneysCount; }
    int GetMoneys() { return itsMoneysCount; }
 
    void Accept() { WorkersDB::cache.push_back(this); }
 
    static Worker* GetWorker(int workerId);
private:
    int itsWorkerId;
    int itsMoneysCount;
};
 
 
 
Worker* Worker::GetWorker(int workerId)
{
    // пытаюсь найти по ID из статического вектора
    for(vector <Worker*>::iterator it = WorkersDB::cache.begin(); it<WorkersDB::cache.end(); ++it)
    {
        if((*it)->GetWorkerId() == workerId)
            return (*it);
    }
 
    return NULL;
}
 
void main()
{
    Worker w(1); // объявляем ID рабочего
    w.AddMoneys(5000); // добавляем деньги
    w.Accept(); // записываем его в вектор
 
    if(Worker* finder = finder->GetWorker(1)) // находим рабочего
        cout << finder->GetMoneys() << endl;
 
    cin.get();
}
Компиляцирует без ошибок, но ошибка компоновки:
HTML5
1
error LNK2001: неразрешенный внешний символ ""public: static class std::vector<class Worker *,class std::allocator<class Worker *> > WorkersDB::cache" (?cache@WorkersDB@@2V?$vector@PAVWorker@@V?$allocator@PAVWorker@@@std@@@std@@A)"
 
Текущее время: 18:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru