Форум программистов, компьютерный форум, киберфорум
C (Си)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 25.04.2022
Сообщений: 2

Вызвано исключение: нарушение доступа для чтения. **temp** было 0xFFFFFFFFFFFFFFD3

25.04.2022, 15:42. Показов 700. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите, не могу понять что именно нужно исправить, уже и переделывал, а исключение как было так и остаеться, строго не судите, я только учусь
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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
#define _CRT_SECURE_NO_WARNINGS
#include <Windows.h>
#include <stdio.h>
#include <malloc.h>
#define M 5
typedef struct book
{
    char name[20];
    char author[20];
    int pages;
    int year;
    char style[20];
    void* value;
    struct book* next;
    struct book* prev;
} bookNode; // Структура вузол
char nameN[10][20] = { "Ти", "Чужий", "Єдина", "Спрага", "Метаморфози", "Інферно", "Космос", "Вчитель", "Прислуга", "Поліанна" }; //10
char authorN[10][20] = { "Кліффорд С.", "Портер Е.", "Стокетт К.", "Дяченко С.", "Зам'ятин Д.", "Денисова О.", "Саган К.", "Шустик М.", "Петров А.", "Перник В." };//10
char styleN[10][20] = { "Фантастика", "Філософська", "Детектив", "Драма", "Пригоди", "Наукова", "Любов", "Історія", "Майбутнє" };//9
typedef struct DBList
{
    size_t size;
    book* head;
    book* tail;
} DBListNode; // Структура двохзв'язний список
void add(DBListNode* list, book* node)
{
    if (list->size == 0)
    {
        list->head = node;
        list->tail = node;
        list->size++;
    }
    else
    {
        list->tail->next = node;
        node->prev = list->tail;
        list->tail = node;
        list->size++;
    }
}
void print(DBListNode* list)
{
    book* temp = list->head;
    while (temp != NULL)
    {
        printf("Назва книги: %s\nАвтор: %s\nКіл-ть сторінок: %d\nРік випуску: %d\nСтиль: %s\n\n", temp->name, temp->author, temp->pages, temp->year, temp->style);
        temp = temp->next;
    }
}
book* pop(DBListNode* list)
{
    book* temp = list->head;
    if (list->size == 1)
    {
        list->head = NULL;
        list->tail = NULL;
        list->size--;
        return temp;
    }
    else
    {
        list->head = list->head->next;
        list->head->prev = NULL;
        list->size--;
        return temp;
    }
}
void replace(DBListNode* list, book* node1, book* node2)
{
    if (node1->prev == NULL)
    {
        list->head = node2;
        node2->next = node1->next;
        node2->prev = NULL;
        node1->next->prev = node2;
        list->size++;
    }
    else if (node1->next == NULL)
    {
        list->tail = node2;
        node2->prev = node1->prev;
        node2->next = NULL;
        node1->prev->next = node2;
        list->size++;
    }
    else
    {
        node1->prev->next = node2;
        node1->next->prev = node2;
        node2->prev = node1->prev;
        node2->next = node1->next;
        list->size++;
    }
}
void printToFile(DBListNode* list)
{
    book* temp = list->head;
    FILE* f = fopen("C:\\Users\\vladl\\Desktop\\test\\bookInf.txt", "w");
    while (temp != NULL)
    {
        fprintf(f, "%s %s %d %d %s\n", temp->name, temp->author, temp->pages, temp->year, temp->style);
        temp = temp->next;
    }
    fclose(f);
}
int getRandomNumber(int min, int max)
{
    static const double fraction = 1.0 / (static_cast<double>(RAND_MAX) + 1.0);
    return static_cast<int>(rand() * fraction * (max - min + 1) + min);
}
 
int main()
{
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    FILE* bookInf; struct book a[M];
    printf("-----------------------\n");
    printf("|Створюємо список книг|\n");
    printf("-----------------------\n\n");
    DBListNode* list = (DBListNode*)malloc(sizeof(DBListNode));
    list->size = NULL;
    list->head = NULL;
    list->tail = NULL;
    for (int i = 0; i < M; i++)
    {
        printf("Назва книги: %s\n", strcpy(a[i].name, nameN[rand() % 10]));
        printf("Автор: %s\n", strcpy(a[i].author, authorN[rand() % 10]));
        printf("Кіл-ть сторінок: %d\n", a[i].pages = getRandomNumber(150, 900));
        printf("Рік випуску: %d\n", a[i].year = getRandomNumber(1950, 2022));
        printf("Стиль: %s\n\n", strcpy(a[i].style, styleN[rand() % 9]));
        add(list, &a[i]);
    }
    //print by year
    printf("-----------------------------------------\n");
    printf("|Виведення книг за заданим роком випуску|\n");
    printf("-----------------------------------------\n\n");
    print(list);
    printf("-----------------------------------------\n");
    printf("|Видалення першого елемента списку|\n");
    printf("-----------------------------------------\n\n");
    book* temp = pop(list);
}
Миниатюры
Вызвано исключение: нарушение доступа для чтения. **temp** было 0xFFFFFFFFFFFFFFD3  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.04.2022, 15:42
Ответы с готовыми решениями:

Вызвано исключение: нарушение доступа для записи. M было 0x1110112
Добрый день, форумчане! Нужна помощь! Задача в том чтобы найти определитель матрицы, но данный алгоритм при матрицах размером больше...

Вызвано исключение: нарушение доступа для записи. **c2** было 0x1A80112
Ошибка на строке c1 = c1; в void copy пример работы программы vvedite stroku: {qqq{www{eee{{}}r}t}. Результат eeerwwwrt{qqq БЕЗ ╠ ...

Вызвано исключение: нарушение доступа для чтения. temp было nullptr
Всем привет! Очень нужна помощь. Пишу курсач по симуляции покупки и продажи изделий компанией через стек. Вроде бы большая часть...

3
599 / 421 / 137
Регистрация: 02.10.2008
Сообщений: 1,798
Записей в блоге: 1
25.04.2022, 16:22
Bash
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
1.c:17:58: ошибка: initializer-string for «char [20]» is too long [-fpermissive]
   17 | char nameN[15][20] = { "Ти", "Чужий", "Єдина", "Спрага", "Метаморфози", "Інферно", "Космос", "Вчитель", "Прислуга", "Поліанна" }; //10
      |                                                          ^~~~~~~~~~~~~
1.c:18:26: ошибка: initializer-string for «char [20]» is too long [-fpermissive]
   18 | char authorN[15][20] = { "Кліффорд С.", "Портер Е.", "Стокетт К.", "Дяченко С.", "Зам'ятин Д.", "Денисова О.", "Саган К.", "Шустик М.", "Петров А.", "Перник В." };//10
      |                          ^~~~~~~~~~~~~
1.c:18:97: ошибка: initializer-string for «char [20]» is too long [-fpermissive]
   18 | char authorN[15][20] = { "Кліффорд С.", "Портер Е.", "Стокетт К.", "Дяченко С.", "Зам'ятин Д.", "Денисова О.", "Саган К.", "Шустик М.", "Петров А.", "Перник В." };//10
      |                                                                                                 ^~~~~~~~~~~~~
1.c:19:25: ошибка: initializer-string for «char [20]» is too long [-fpermissive]
   19 | char styleN[15][20] = { "Фантастика", "Філософська", "Детектив", "Драма", "Пригоди", "Наукова", "Любов", "Історія", "Майбутнє" };//9
      |                         ^~~~~~~~~~~~
1.c:19:39: ошибка: initializer-string for «char [20]» is too long [-fpermissive]
   19 | char styleN[15][20] = { "Фантастика", "Філософська", "Детектив", "Драма", "Пригоди", "Наукова", "Любов", "Історія", "Майбутнє" };//9
      |
У меня даже не компилируется. Кирилические названия не влазят в 20 байт
0
0 / 0 / 0
Регистрация: 25.04.2022
Сообщений: 2
25.04.2022, 16:27  [ТС]
я могу его и скомпилировать и вывести в консоль, выделил названиям 999 байт, а ошибка все равно не пропала
Миниатюры
Вызвано исключение: нарушение доступа для чтения. **temp** было 0xFFFFFFFFFFFFFFD3  
0
599 / 421 / 137
Регистрация: 02.10.2008
Сообщений: 1,798
Записей в блоге: 1
25.04.2022, 17:27
Мне лень переписывать всю прогу под wchar_t перевёл все тексты в английский всё работает:
Code
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
faust@Rizen53600 ~/П/C/РАзная всячина> ./a.out
-----------------------
|Building list of book|
-----------------------
 
Book Name: Thirst
Autor: Sagan K.
Pages: 738
Year: 2008
Style: Science
 
Book Name: Inferno
Autor: Sagan K.
Pages: 726
Year: 1970
Style: Filosofie
 
Book Name: One
Autor: Shustik M.
Pages: 423
Year: 1987
Style: Science
 
Book Name: Space
Autor: Clifford S.
Pages: 688
Year: 1960
Style: Filosofie
 
Book Name: Alien
Autor: Petrov A.
Pages: 253
Year: 2008
Style: Future
 
-----------------------------------------
|Books in Year range |
-----------------------------------------
 
Book Name: Thirst
Autor: Sagan K.
Pages: 738
Year: 2008
Style: Science
 
Book Name: Inferno
Autor: Sagan K.
Pages: 726
Year: 1970
Style: Filosofie
 
Book Name: One
Autor: Shustik M.
Pages: 423
Year: 1987
Style: Science
 
Book Name: Space
Autor: Clifford S.
Pages: 688
Year: 1960
Style: Filosofie
 
Book Name: Alien
Autor: Petrov A.
Pages: 253
Year: 2008
Style: Future
 
-----------------------------------------
|Delete first element|
-----------------------------------------
Думаю, что проблема всё-таки в кодировках. Если бы у меня использовалась однобайтная KOI-8, то и с кирилицей всё отработало бы. Но лень перелопачивать под длинный символ прогу.
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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <malloc.h>
#define M 5
typedef struct book
{
    char name[20];
    char author[20];
    int pages;
    int year;
    char style[20];
    void* value;
    struct book* next;
    struct book* prev;
} bookNode; // Структура вузол
char nameN[10][999] = { "You", "Alien", "One", "Thirst", "Metamorphoses", "Inferno", "Space", "Teacher", "Servants", "Pollyanna" }; //10
char authorN[10][999] = { "Clifford S.", "Porter E.", "Stokett K.", "Dyachenko S.", "Zamyatin D.", "Denisova O.", "Sagan K.", "Shustik M.", "Petrov A.", "Pernik V." };//10
char styleN[10][999] = { "Fantastica", "Filosofie", "Detective", "Drama", "Adventures", "Science", "Love", "Historical", "Future" };//9
typedef struct DBList
{
    size_t size;
    book* head;
    book* tail;
} DBListNode; // Структура двохзв'язний список
void add(DBListNode* list, book* node)
{
    if (list->size == 0)
    {
        list->head = node;
        list->tail = node;
        list->size++;
    }
    else
    {
        list->tail->next = node;
        node->prev = list->tail;
        list->tail = node;
        list->size++;
    }
}
void print(DBListNode* list)
{
    book* temp = list->head;
    while (temp != NULL)
    {
        printf("Book Name: %s\nAutor: %s\nPages: %d\nYear: %d\nStyle: %s\n\n", temp->name, temp->author, temp->pages, temp->year, temp->style);
        temp = temp->next;
    }
}
book* pop(DBListNode* list)
{
    book* temp = list->head;
    if (list->size == 1)
    {
        list->head = NULL;
        list->tail = NULL;
        list->size--;
        return temp;
    }
    else
    {
        list->head = list->head->next;
        list->head->prev = NULL;
        list->size--;
        return temp;
    }
}
void replace(DBListNode* list, book* node1, book* node2)
{
    if (node1->prev == NULL)
    {
        list->head = node2;
        node2->next = node1->next;
        node2->prev = NULL;
        node1->next->prev = node2;
        list->size++;
    }
    else if (node1->next == NULL)
    {
        list->tail = node2;
        node2->prev = node1->prev;
        node2->next = NULL;
        node1->prev->next = node2;
        list->size++;
    }
    else
    {
        node1->prev->next = node2;
        node1->next->prev = node2;
        node2->prev = node1->prev;
        node2->next = node1->next;
        list->size++;
    }
}
void printToFile(DBListNode* list)
{
    book* temp = list->head;
    FILE* f = fopen("C:\\Users\\vladl\\Desktop\\test\\bookInf.txt", "w");
    while (temp != NULL)
    {
        fprintf(f, "%s %s %d %d %s\n", temp->name, temp->author, temp->pages, temp->year, temp->style);
        temp = temp->next;
    }
    fclose(f);
}
int getRandomNumber(int min, int max)
{
    static const double fraction = 1.0 / (static_cast<double>(RAND_MAX) + 1.0);
    return static_cast<int>(rand() * fraction * (max - min + 1) + min);
}
 
int main()
{
/*    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);*/
    FILE* bookInf; struct book a[M];
    printf("-----------------------\n");
    printf("|Building list of book|\n");
    printf("-----------------------\n\n");
    DBListNode* list = (DBListNode*)malloc(sizeof(DBListNode));
    list->size = 0L;
    list->head = NULL;
    list->tail = NULL;
    for (int i = 0; i < M; i++)
    {
        printf("Book Name: %s\n", strcpy(a[i].name, nameN[rand() % 10]));
        printf("Autor: %s\n", strcpy(a[i].author, authorN[rand() % 10]));
        printf("Pages: %d\n", a[i].pages = getRandomNumber(150, 900));
        printf("Year: %d\n", a[i].year = getRandomNumber(1950, 2022));
        printf("Style: %s\n\n", strcpy(a[i].style, styleN[rand() % 9]));
        add(list, &a[i]);
    }
    //print by year
    printf("-----------------------------------------\n");
    printf("|Books in Year range |\n");
    printf("-----------------------------------------\n\n");
    print(list);
    printf("-----------------------------------------\n");
    printf("|Delete first element|\n");
    printf("-----------------------------------------\n\n");
    book* temp = pop(list);
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.04.2022, 17:27
Помогаю со студенческими работами здесь

Вызвано исключение: нарушение доступа для чтения. s было 0x1110112
Товарищи форумчане, нужна ваша помощь! (Для простоты объяснения прикреплю скрин) Насколько я понимаю, проблема заключается в том,...

Вызвано исключение: нарушение доступа для чтения. this было 0xCDCDCDCD
Есть у меня код со структурой с динамическими массивами внутри. Через клаву я ввожу данные. И получается, что &quot;subjects&quot; я могу...

Вызвано исключение: нарушение доступа для чтения. q было nullptr
Всем привет! Дана задача: Даны два линейных однонаправленных списка L1 и L2. Разработать функцию, которая формирует список L,...

Вызвано исключение: нарушение доступа для чтения. p было 0x1110113
В функциях постоянно выдает ошибку чтения (первую ошибку выдает в 42ой строке) #include &lt;stdio.h&gt; //подключаем библиотеки ...

Вызвано исключение: нарушение доступа для чтения. this было nullptr
Добрый день. При попытке ввода значений выдает: Вызвано исключение: нарушение доступа для чтения. this было nullptr. Никак не могу...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
Контроль уникальности заводского номера - вариант №2
Maks 24.03.2026
В отличие от предыдущего варианта добавлено прерывание циклов, также добавлены новые переменные для сохранения контекста ошибки перед прерыванием цикла: Процедура ПередЗаписью(Отказ, РежимЗаписи,. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера - вариант №1
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru