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

Как достать объект-контейнер, а не его элемент - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Упорядочивание массива структур по нескольким полям http://www.cyberforum.ru/cpp-beginners/thread1203105.html
Есть программа,которая сортирует студентов по году рождения. #include <conio.h> #include <iostream> #include <stdio.h> const int n=3; struct student { char fio; char god; };
C++ Не хочет компилироваться, код верный Вроде бы и простая фигня, но.. не могу откомпилировать. Помогите разобраться. #include<iostream.h> const n=50; void main() { int* m = new int n; int k,i,c,f; cout<<"\nВведите количество элементов массива(<=50)"; cin>>k; cout<<"\nВведите "<<k<<" чисел"; http://www.cyberforum.ru/cpp-beginners/thread1203099.html
Районная олимпиада по программированию 2011-12 (ошибка!) C++
Похоже что я нашел ошибку помогите мне подтвердив ее или опровергнуть вот задача ! Для иллюстрации метода математической индукции в учебниках времен СССР всегда приводилась следующая задача: «Доказать, что любую целую сумму денег, начиная с 8 руб., Можно без сдачи разменять купюрами по 3 и 5 руб.». Вам не нужно ничего доказывать, а необходимо просто написать программу, которая для двух типов...
C++ Определитель матрицы. Символьный вид
Написать программу которая выводит формулу определитель матрицы в символьном виде для n-го случая. Есть код для нахождения диагоналей. Но в нем вроде не работает ss >> tstr; #include <iostream> #include <sstream> #define BASE 3 using namespace std; int main() {
C++ Анализ твиттов http://www.cyberforum.ru/cpp-beginners/thread1203058.html
#include <iostream> #include <fstream> #include <sstream> #include <iterator> #include <vector> #include <map> #include <string> using namespace std; map<int, int> Max_Time; struct Time
C++ Копирование элементов из старой матрицы в новую. Динамическое распределение памяти Столкнулся с такой задачей : Вводится матрица. Если в матрице наибольший элемент находится над главной диагональю, то программа формирует новую матрицу, удалив из исходной столбец и строку, на пересечении которых находится наибольший элемент. Распределение памяти - динамическое. Вот мой код (MVS 2008): // vvod.cpp ФУНКЦИЯ ВВОДА #include <iostream> using namespace std; float*... подробнее

Показать сообщение отдельно
kordax
4 / 4 / 1
Регистрация: 08.06.2014
Сообщений: 89
15.06.2014, 01:21  [ТС]     Как достать объект-контейнер, а не его элемент
allocator.h
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
#include <string.h>
 
using namespace std;
 
template<class T>
class allocat {
public:
T* allocate (int n);
void deallocate(T* p, int n);
void construct(T* p, const T& v);
void destroy(T* p);
};
 
template<class T>
T* allocat<T>::allocate(int n)
{
    if (n == 0) return NULL;
    T* p;
    p = (T*) malloc(n * sizeof(T));
    return p;
}
 
template<class T>
void allocat<T>::deallocate(T* p, int n)
{
    if (n == 0) return;
    for (int i = 0; i < n; i++)
    {
        free(p);
        p++;
    }
    return;
}
 
template<class T>
void allocat<T>::construct(T* p, const T& v)
{
    p = new T;
    *p = v; // [B]Ошибка именно на этом этапе[/B]
}
 
template<class T>
void allocat<T>::destroy(T* p)
{
    delete p;
    return;
}
templates.h
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
#include <string>
#include <iostream>
#include <stdlib.h>
#include <vector>
#include <allocator.h>
 
using namespace std;
 
template <class T, class A = allocat<T> > class S
{
public:
    unsigned int buffer;
    unsigned int size;
    T* val;
    A alloc;
public:
    //S(T t) : val(t) { cout << "Constructor called" << endl; }
 
    S() :size(0), buffer(0), val(0) { cout << "Default constructor called" << endl; }
    S(const unsigned int newsize) :size(0), buffer(0), val() { resize(newsize); }
    ~S() { free(val); cout << "Destructor called" << endl; } //val && this->val выдавали разное значение??? Не ясно почему.
 
    void initialize(const unsigned int);
//===========================================================
    void operator=(const string&);
    istream& operator>> (istream&);
    T& operator[](unsigned int);
    const T& operator[](const unsigned int) const;
    T& get_val();
    void set_val(const T&);
    void read_val (T&);
//===========================================================
    void reserve(const unsigned int);
    void resize(const unsigned int);
    void push_back(const T&);
//===========================================================
 
};
 
template <class T, class A>
void S<T, A>::reserve(const unsigned int newalloc)
{
    if (newalloc <= buffer) return;
    T* newmemory = alloc.allocate(newalloc);
    //=======================================================
    for (int i = size; i < newalloc; ++i)
    {
        alloc.construct(&newmemory[i], val[i]); // копируем
    }
    if (val) for (int i = size; i < newalloc; ++i)
    {
        alloc.destroy(&val[i]); // уничтожаем
    }
    //=======================================================
    alloc.deallocate(val, buffer); // освобождаем старую память
    val = newmemory;
    buffer = newalloc;
    size = newalloc;
}
 
template <class T, class A>
void S<T,A>::resize(const unsigned int newsize)
{
    if (newsize == 0) return;
    if (newsize < 0)
    {
        int cnt = 0;
        for (int i = 0; i < size; i++)
        {
            cnt++;
            if (i > newsize) delete val;
            val++;
        }
        val == val - cnt;
        return;
    }
    reserve(newsize);
    return;
}
main.cpp
C++
1
2
3
4
5
6
7
8
9
10
11
12
#include <templates.h>
 
using namespace std;
 
int main()
{
    S<int> s_int(2);
    S<double> s_double(2);
    S<char> s_char(2);
    S<string> s_vec(3);
    return 0;
}
Постарался убрать всё лишнее.
Проблема возникает здесь:
C++
1
2
3
4
5
void allocat<T>::construct(T* p, const T& v)
{
    p = new T;
    *p = v; // [B]Ошибка именно на этом этапе[/B]
}
Т.е. получается так, что при вызове конструктора по умолчанию, нужно выполнить allow.construct (мне ведь нужно создать объекты string), но в итоге, v пусто и *p вылетает при попытки присваивания несуществующего значения.
 
Текущее время: 22:17. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru