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

Access Violation при работе с очередью - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Class matrix http://www.cyberforum.ru/cpp-beginners/thread813555.html
Организовать класс матрица, содержащий методы вывода матрицы в общепринятом виде, нахождения транспонированной матрицы, и определитея матрицы. P.S. Помогите начинающему , буду очень благодарен)))
C++ Не могу понять где ошибка! int _tmain(int argc, _TCHAR* argv) { int W , Color , i,j, k; rebro Reb; setlocale(LC_ALL, "");//вывод кирилицы не кракозябрами cout<<"Введите м-у W : "; cin>>W; for ( k = 0; k < N-1; k ++ ) { for ( i = 0; i < N-1; i ++ ) http://www.cyberforum.ru/cpp-beginners/thread813544.html
Надо указателю на long int присвоить значение указателя на char C++
//есть указатель unsigned char* p_to_char = somthing; //и указатель unsigned long int* p_to_int; //надо p_to_int присвоить значение p_to_char; p_to_int = p_to_char
C++ Считывание символов с файла
Нужна программ которая считывала бы буквы с файла и выводила их количество. Попробовал сделать. Но мне вместо суммы выдает на каждый символ 1 значение. И выдает эти символы в ряд. #include <stdio.h> #include <stdlib.h> int main() { FILE *fi; int ch; if(fi=fopen("File.txt","r")){ while((ch= getc(fi))!=EOF)
C++ Бинарный поиск последнего нужного нам элемента http://www.cyberforum.ru/cpp-beginners/thread813523.html
while (first < last) { mid = (first + last) >> 1; if (a >= x) { last = mid; } else { first = mid + 1;
C++ Перегрузка оператора + и = Здравствуйте! Возникла проблема при реализации кода перегрузки операторов. BigInt - это просто класс характеризующий огромные числа в длинной арифметике. В массиве digits, вот такая запись 000123 будет хранится как 321000. Цель: заставить работать вот такое a=a+b, или хотя бы вот такое c=a+b. #include <iostream> #include <string> using namespace std; подробнее

Показать сообщение отдельно
Nastik-kum
0 / 0 / 0
Регистрация: 20.03.2013
Сообщений: 16

Access Violation при работе с очередью - C++

20.03.2013, 15:40. Просмотров 333. Ответов 1
Метки (Все метки)

Здравствуйте. Есть такая проблема. Необходимо создать очередь массивов и соответственно работать с ней. В результате долгих мучений родила вот такой класс:
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
class Queue {
 
public:
    static const int SIZE = 10;
    unsigned char queueM[SIZE][188];
    unsigned int head;
    unsigned int tail;
        bool QueueIsFull;
        bool QueueIsEmpty;
        unsigned char res[188];
        Queue(void) {
            for (int i = 0; i < SIZE; i++)
            {
                for (int j = 0; j < 188; j++)
                {
                    queueM[i][j] = 0;
                    res[j] = 0;
                }
            }
            head = 0;
            tail = 0;
            QueueIsFull = false;
            QueueIsEmpty = true;
        }
   ~Queue() {
        this->clear();
        QueueIsFull = false;
    }
public:
   void  push(unsigned char * d) {
       if (QueueIsFull)
       {
          // errc("Queue is full");
           printf("Queue is full");
           return;
       }
       else
       {
           for (int i = 0; i < 188; i++)
           {
               queueM[tail][i] = d[i];
           }
           if (tail == SIZE)
           {
               tail = 0;
           }
           else
           {
               tail ++;
           }
           if (tail == head)
           {
               QueueIsFull = true;
           }
           QueueIsEmpty = false;
       }
       
    }
 
   void front(unsigned char *res) {
        
        for (int i = 0; i < 188; i++)
        {
            res[i] = queueM[head][i];
        }
    //  return queueM[head];
    }
 
    void  pop(void) {
        if (!QueueIsEmpty)
        {
            for (int i = 0; i < 188; i++)
        {
            queueM[head][i] = 0;
        }
        if (head < SIZE)
        {
            head ++;
        }
        else
        {
            head = 0;
        }
        if (head > tail)
        {
            QueueIsEmpty = true;
        }
        QueueIsFull = false;
        }
        else
        {
            printf("Qeue is empty!!!");
        }
   }
 
   bool empty(void) const {
       return QueueIsEmpty;
   }
 
   void clear(void) {
     for (int i = 0; i < SIZE; i++)
            {
                for (int j = 0; j < 188; j++)
                {
                    queueM[i][j] = 0;
                }
            }
            head = 0;
            tail = 0;
            QueueIsFull = false;
            QueueIsEmpty = true;
   }
};
Вроде как создается все нормально. Однако когда я работаю с данной очередью в какой-то момент выбивает ошибку Access violation. Что бы это могло значить? Добавляю сюда еще использование очереди.
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
 case 0x0065: case 0x00c8:
                      {
                          if (!Prog161.QueueIsFull)
                          {
                              Prog161.push(arr);
                              unsigned long long int pcr = 0;
                              unsigned char res[188];
                              Prog161.front(res);
                              if (check_AF(res,&pcr))
                              {
                                  fprintf(allPCRs,"Program %x : PCR = %llu ",a1,pcr);
                                  for (int i = 0; i < 188; i++)
                                  {
                                      Prog161.front(res);
                                      fprintf(allPCRs,"%x ",res[i]);
                                  }
                                  fprintf(allPCRs,"\n");
                              }
                          }
                          else
                          {
                              unsigned char res[188];
                              Prog161.front(res);
                              fwrite(res,sizeof(unsigned char), 188, f161);
                              Prog161.pop();
                          }
                          break;
                      }
Подскажите, пожалуйста, в чем может быть ошибка?

Добавлено через 39 минут
Дебагер говорит, что тормозится тут
C++
1
2
3
4
5
6
7
8
9
void __cdecl _unlock (
        int locknum
        )
{
        /*
         * leave the critical section.
         */
        LeaveCriticalSection( _locktable[locknum].lock );
}
Добавлено через 1 час 26 минут
Уже все сделала. Тему можно закрывать.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 10:23. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru