Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Объявление и инициализация динамической матрицы https://www.cyberforum.ru/ cpp-beginners/ thread888391.html
Ребят, только начал разбираться с матрицой. примерно я знаю как написать матрицу, но не знаю как написать динамическую матрицу, и чтоб размеры матрицы вводилось с клавиатуры. помогите написать
Dev-C++ не компилирует программу C++
Dev-C++ перестал компилировать код C++ я пробовал скомпилировать код из книги "C++ для чайников": // // Program to convert temperature from Celsius degree // units into Fahrenheit degree...
C++ Создание собственных процедур и функций
Создание собственных процедур и функций. Написать функцию для расчета математической формулы, согласно варианту и процедуры для ввода и вывода данных Файл с значениями вложил...помогите пожалуйста
C++ Удаление элемента со списка Вот у меня есть код: #include "stdafx.h" #include <iostream> #include <conio.h> using namespace std; struct OS { char Name ; int Roz; int Op; }; https://www.cyberforum.ru/ cpp-beginners/ thread888362.html
C++ Почему не работает счетчик в функции? https://www.cyberforum.ru/ cpp-beginners/ thread888359.html
я написал вот такую не хитрую функцию , в ней все работает как надо,кроме переменной "V" - в чем проблема?(rm и lm это сокращенный код (GetAsyncKeyState(VK_(L\R)BUTTON)&1) void RetCoord (int X , int...
Написать программу, которая удаляет из введенного строки любой необходимый введен с клавиатуры символ. Процесс удаления выделите в отдельную процедуру C++
Здравствуйте, Уважаемые. Очень срочно нужна Ваша помощь, в решении данной задачи: Написать программу, которая удаляет из введенного строки любой необходимый введен с клавиатуры символ. Процесс...
C++ Заданная последовательность целых чисел. Найти количество чисел, делящихся на 3 и 5 без остатка
Здравствуйте, Уважаемые. Очень срочно нужна Ваша помощь, в решении данной задачи: Заданна последовательность целых чисел. Найти количество чисел, делящихся на 3 и 5 без остатка.
C++ В матрице М (N, M) найти сумму элементов четных строк Здравствуйте, Уважаемые. Очень срочно нужна Ваша помощь, в решении данной задачи: В матрице М (N, M) найти сумму элементов четных строк. https://www.cyberforum.ru/ cpp-beginners/ thread888349.html
C++ Вывести все слова в предложении в которых нет повторяющихся букв https://www.cyberforum.ru/ cpp-beginners/ thread888347.html
Вывести все слова в предложении в которых нет повторяющихся букв. Как это реализовать ? Желательно примеры, заранее спасибо
C++ Програма для диплома Здраствуйте, как видно по теме мне нужно зделать програму для диплома програма должна находить 2 файлы с одинаковым размером разширением и названием но я даже не представляю как зделать такой поиск... https://www.cyberforum.ru/ cpp-beginners/ thread888345.html
В астрале
Эксперт С++
8026 / 4783 / 654
Регистрация: 24.06.2010
Сообщений: 10,558
03.06.2013, 11:46 0

allocator своя версия

03.06.2013, 11:46. Просмотров 907. Ответов 8
Метки (Все метки)

Ответ

Droll, В С++ запрещено неявное преобразование от void* к T*, т.е. такой код не скомпилируется
C++
1
2
3
4
5
6
#include <cstdlib>
 
int main()
{
   int* p = malloc(sizeof(int));
}
Поэтому нужно добавлять явное преобразование.

C++
1
2
3
4
5
6
#include <cstdlib>
 
int main()
{
   int* p = static_cast<int*>(malloc(sizeof(int)));
}
Контейнеры рассчитывают на то, что allocate будет возвращать
C++
1
allocator::pointer
, потому не делают явных кастов.

Добавлено через 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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#include <cstdlib>
#include <memory>
#include <vector>
 
template<typename T>
class allocator
{
public:
   typedef T value_type;
   typedef T* pointer;
   typedef const T* const_pointer;
   typedef T& reference;
   typedef const T& const_reference;
   typedef size_t size_type;
   typedef ptrdiff_t difference_type;
 
   template<typename U>
   struct rebind
   {
      typedef allocator<T> other;
   };
 
   allocator() {}
   allocator(const allocator&) {}
   template<typename U>
   allocator(const allocator<T>&) {}
 
   pointer allocate(size_type n, const void* = 0)
   {
      return static_cast<pointer>(malloc(n * sizeof(T)));
   }
   void deallocate(pointer p, size_type)
   {
      free(p);
   }
   void construct(pointer p, const T& value)
   {
      new (p) T(value);
   }
   void destruct(pointer p)
   {
      p->~T();
   }
   size_type max_size()
   {
      return std::allocator<T>::max_size();
   }
   pointer address(reference x) const
   {
      return const_cast<pointer>(address(const_cast<const_reference>(x)));
   }
   const_pointer address(const_reference x) const
   {
      return std::allocator<T>().address(x);
   }
};
 
template<typename T>
bool operator == (const allocator<T>&, const allocator<T>&)
{
   return true;
}
 
template<typename T>
bool operator != (const allocator<T>& lhs, const allocator<T>& rhs)
{
   return !(lhs == rhs);
}
 
int main()
{
   std::vector<int, allocator<int> > vector;
   vector.push_back(1);
}


Вернуться к обсуждению:
allocator своя версия
2
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
03.06.2013, 11:46
Готовые ответы и решения:

Своя версия функции strcmp()
В книге дано задание, создать свою версию функции strcmp(). Подскажите как можно это реализовать,...

Распределитель памяти идентичный std::allocator. Непонятные синтаксис и концепция std::allocator::construct
Компилятор: MSVC 2010 Exress код моего класса распределяющего память под спойлером #include...

Своя версия программы rm
Всем привет, нужно написать такую программу: Напишите свою версию программы rm, используя вызов...

allocator
Здорова! Есть задачка:&quot;Завершите или реализуйте с самого начала Pool_alloc (параграф 19.4.2) так,...

8
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2020, vBulletin Solutions, Inc.