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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
taras atavin
Ушёл с форума.
3569 / 1752 / 91
Регистрация: 24.11.2009
Сообщений: 27,619
#1

Класс, знающий все свои экземляры - C++

19.04.2013, 20:40. Просмотров 264. Ответов 5
Метки нет (Все метки)

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
class A
{
 protected:
  static A **ptr;
  static size_t ptrcount;
 public:
 A ()
 {
  A **s;
  A **t;
  A **p=new A*[ptrcount+1];
  p[ptrcount]=this;
  if (this->ptr)
  {
   for (t=p+ptrcount-1, s=ptr+ptrcount-1; s>=ptr; --s, --t)
   {
    *t=*s;
   }
   delete [] ptr;
  }
  ptr=p;
  ++ptrcount;
 }
 A (A &a)
 {
  A **s;
  A **t;
  A **p=new A*[ptrcount+1];
  p[ptrcount]=this;
  if (this->ptr)
  {
   for (t=p+ptrcount-1, s=ptr+ptrcount-1; s>=ptr; --s, --t)
   {
    *t=*s;
   }
   delete [] ptr;
  }
  ptr=p;
  ++ptrcount;
 }
 ~A ()
 {
  A **s;
  A **t;
  A **p=new A*[ptrcount+1];
  if (ptrcount>1)
  {
   for (t=this->ptr+ptrcount-1; t>=this->ptr; --t)
   {
    if (*t==this)
    {
    *t=ptr[ptrcount-1];
    }    
   }
   for (t=p+ptrcount-2, s=ptr+ptrcount-2; s>=ptr; --s, --t)
   {
    *t=*s;
   }
   delete [] ptr;
   ptr=p;
   --ptrcount;
  }
  else
  {
   delete [] ptr;
   ptr=null_ptr;
   ptrcount=0;
  }
 }
};
static A *ptr=NULL;
static size_t ptrcount=0;
Есть замечания?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.04.2013, 20:40     Класс, знающий все свои экземляры
Посмотрите здесь:

Класс, знающий все свои экземпляры - C++
Некий класс, пусть его зовут A. В разных частях программы валяются строки A a;, A b;, A *p=new A;, static A c;, static A *d=new A; и тому...

Почему перезаписываются предыдущие экземляры - C++
Проблема в том что всем предыдущим полям присваивается значение последнего(надеюсь что ясно выразился) Вот код: #include...

Шаблонный класс очереди. Выводит сначала все индексы, потом все элементы - C++
#include <iostream> #include <conio.h> using namespace std; const int SIZE=100; template<class X> class queue{ X q; ...

Аналог realloc, знающий классы и вызывающий конструкторы/деструкторы - C++
Можно ли сделать такой шаблон? class A { }; class B { }; A *a; B *b; a=MyReAlloc(a, 1024); // Размер куска памяти по...

Знающий человек, не проходи мимо, найди ошибку. И будут тебе лучи добра и счастья - C++
#include <iostream> #include <stdlib.h> #include <time.h> using namespace std; int rez() { int kubik_1=rand()%5+1; int...

Класс field, все поля private - C++
Здравствуйте. Такое дело: некорректно выводится длина и ширина объекта "field", следовательно - площадь. Как переделать программу так,...

Класс vector. Заменить все элементы в интервале [a,b] на x. - C++ - C++
Дана последовательность из n целых чисел. Занести их в вектор. Заменить все элементы, попадающие в интервал на x. Вывод вектора на...

Класс, который удаляет из строки все пробелы - C++
Нужен класс, который удаляет из строки все пробелы. Как сие лучше реализовать? Придумалось вот такое: #include <iostream> #include...

Класс: показать все варианты замены провода без повторов - C++
Доброго всем времени суток!Большая просьба кому не трудно покритиковать и указать на мои косяки желательно с разъяснениями.Изучаю я с++...

Обязан ли дочерний класс реализовать все виртуальные функции отца? - C++
Обязан ли дочерний класс реализовать все виртуальные функции отца? Такой вот вопрос у меня на ум пришел, правильно ли? или я в чем то...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ForEveR
В астрале
Эксперт С++
7970 / 4732 / 320
Регистрация: 24.06.2010
Сообщений: 10,541
Завершенные тесты: 3
19.04.2013, 20:45     Класс, знающий все свои экземляры #2
taras atavin, Угу. Во первых вместо указателя на указатель лучше юзать вектор указателей.
Во вторых

C++
1
2
static A *ptr=NULL;
static size_t ptrcount=0;
Должно выглядеть как

C++
1
2
A* A::ptr = NULL;
size_t A::ptrcount = 0;
Ну и в заключение: совершенно ненужный изврат же ведь.
taras atavin
Ушёл с форума.
3569 / 1752 / 91
Регистрация: 24.11.2009
Сообщений: 27,619
19.04.2013, 20:47  [ТС]     Класс, знающий все свои экземляры #3
Зачем это нужно, вопрос отдельный, здесь разбираем реализацию.
ForEveR
В астрале
Эксперт С++
7970 / 4732 / 320
Регистрация: 24.06.2010
Сообщений: 10,541
Завершенные тесты: 3
19.04.2013, 21:08     Класс, знающий все свои экземляры #4
taras atavin, Класс знающий о своих инстансах - само по себе бредово. Вот класс менеджер знающих об инстансах конкретного класса было бы вполне себе ок.

Добавлено через 18 минут
Вот так будет несколько приятнее.
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
#include <vector>
#include <iostream>
#include <string>
 
class A
{
public:
    A(const std::string& n) : name(n)
    {
        push_instance();
    }
    A(const A& rhs) : name(rhs.name)
    {
        push_instance();
    }
    ~A()
    {
        std::cout << "Pop: " << name << std::endl;
        instances.pop_back();
    }
private:
    void push_instance()
    {
        std::cout << "Push: " << name << std::endl;
        instances.push_back(this);
    }
    std::string name;
    static std::vector<A*> instances;
};
 
std::vector<A*> A::instances;
 
int main()
{
    A a("1");
    A b("2");
}
А вот так будет несколько правильнее.

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
#include <vector>
#include <iostream>
#include <string>
 
template<typename T>
class InstanceCounter
{
public:
    static InstanceCounter<T>& instance()
    {
        static InstanceCounter<T> inst;
        return inst;
    }
    void push_instance(const T* const ptr)
    {
        instances.push_back(ptr);
    }
    void pop_instance()
    {
        instances.pop_back();
    }
    int instances_size()
    {
        return instances.size();
    }
private:
    InstanceCounter(const InstanceCounter&);
    InstanceCounter& operator = (const InstanceCounter&);
    InstanceCounter() {}
    std::vector<const T*> instances;
};
 
class A
{
public:
    A(const std::string& n) : name(n)
    {
        push_instance();
    }
    A(const A& rhs) : name(rhs.name)
    {
        push_instance();
    }
    ~A()
    {
        std::cout << "Pop: " << name << std::endl;
        InstanceCounter<A>::instance().pop_instance();
    }
private:
    void push_instance()
    {
        std::cout << "Push: " << name << std::endl;
        InstanceCounter<A>::instance().push_instance(this);
    }
    std::string name;
};
 
int main()
{
    InstanceCounter<A>& cnt = InstanceCounter<A>::instance();
    std::cout << cnt.instances_size() << std::endl;
    {
    A a("1");
    A b("2");
    std::cout << cnt.instances_size() << std::endl;
    }
    std::cout << cnt.instances_size() << std::endl;
}
Nick Alte
Эксперт С++
1608 / 1000 / 118
Регистрация: 27.09.2009
Сообщений: 1,930
Завершенные тесты: 1
19.04.2013, 21:22     Класс, знающий все свои экземляры #5
Цитата Сообщение от ForEveR Посмотреть сообщение
А вот так будет несколько правильнее.
Но не совсем. Этот класс полагается на строгий LIFO порядок создания-уничтожения объектов класса A, и при нарушении этого порядка (что, в общем-то, дело совсем нехитрое) часть указателей начинает показывать на удалённые объекты, а указатели на ещё не уничтоженные объекты теряются.
ForEveR
В астрале
Эксперт С++
7970 / 4732 / 320
Регистрация: 24.06.2010
Сообщений: 10,541
Завершенные тесты: 3
19.04.2013, 22:06     Класс, знающий все свои экземляры #6
Nick Alte, Согласен. Тут логичнее через find действовать ну и закрыть изменения извне, открыв изменения только в нужном классе. Это просто пример.
Yandex
Объявления
19.04.2013, 22:06     Класс, знающий все свои экземляры
Ответ Создать тему
Опции темы

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