Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.56/55: Рейтинг темы: голосов - 55, средняя оценка - 4.56
 Аватар для FlamedoFF
0 / 0 / 0
Регистрация: 17.08.2008
Сообщений: 14

Память не может быть "written"

29.04.2009, 20:14. Показов 11320. Ответов 23
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите найти ошибку в следующем коде:
На этапе вхождения в функцию "vvod_vseh", а именно при вводе первой фамилии - выскакивает ошибка памяти. "Память не может быть written."
Как исправить?
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
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <windows.h>
struct abonent
{
    char familiya[20];
    int year, nomer[7], kolvo;
};
void vvod_vseh(abonent*, int);
void vivod_vseh(abonent*, int);
void sort(abonent*, int);
void vvod(abonent*, int, int);
void vivod(abonent*);
void vivod_s_opred_goda(abonent*, int, int);
 
void main(void)
{
    int god, n, k;
    abonent *p=0;
    printf("Vvedite kol abonentov: \n");
    scanf_s("%d",&n);
    if(n<=0) 
    {
        printf("Nevernoe kolichestvo!");
        return;
    }
 
    vvod_vseh(p,n);
 
    while(1)
    {
        puts("BBeduTe: 1-BblBOD, 2-COPTuPOBKA,");
        puts("0-Exit. \n");
        scanf_s("%d",&k);
        if(!k)
            break;
        switch(k)
        {
        case 1:    vivod(p);
            break;
        case 2:    sort(p,0);
            break;
        }
    printf("Vvedite god: \n");
    scanf_s("%d",&god);
 
    vivod_s_opred_goda(p, n, god);
    }
}
void vvod(abonent*p)
{
    printf("Lastname:\n");
    scanf_s("%s",p->familiya);
    printf("Year:\n");
    scanf_s("%d",&p->year);
    printf("Number:\n");
    scanf_s("&s",p->nomer);
}
 
void vvod_vseh(abonent*p, int n)
{
    for(int i=1;i<n;i++)
        vvod(&p[i]);
}
 
void vivod(abonent*p)
{
    printf("%-20s%-20s%-15d\n", p->familiya, p->year, p->nomer);
}
 
void vivod_s_opred_goda(abonent*p, int n, int god)
{
    int t;
    for(int i=0;i<n;i++)
    {
        t=p[i].year;
        if(t>=god)
        {
            vivod_vseh(&p[i],n);
        }
    }
}
void vivod_vseh(abonent*p, int n)
{
        printf("%-20s%-20s%-15d\n", p->familiya, p->nomer, p->year);
}
void sort(abonent*p, int n)
{
    int i,j,k;
    abonent buf;
    for(i=0;i<n;i++)
    k=i;
    for(j=i+1;j<n;j++)
    {
        if(_strcmpi(p[k].familiya,p[j].familiya)>0)
            k=j;
        buf=p[i];
        p[i]=p[k];
        p[k]=buf;
    }
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.04.2009, 20:14
Ответы с готовыми решениями:

Память не может быть прочитала
Здравствуйте, вот есть код: struct Dyn{ Syt select; Dyn* next; }; ............

Память не может быть прочитана!
Проблема возникает при копировании одного массива в другой. Я вроди просмотрел и размерности вроди совпадают, но может быть я что то...

По каким причинам память не может быть выделена динамически?
Что это могут быть за причины?

23
 Аватар для Mecid
684 / 233 / 16
Регистрация: 15.10.2007
Сообщений: 1,246
29.04.2009, 23:11
Студворк — интернет-сервис помощи студентам
еще там переполнение во время ввода year,он у тя из 4 элементов состомт,а ты обращаешся к пятому
кстати там можно p->year
0
 Аватар для FlamedoFF
0 / 0 / 0
Регистрация: 17.08.2008
Сообщений: 14
29.04.2009, 23:11  [ТС]
Цитата Сообщение от Gravity Посмотреть сообщение
Код C1 56 scanf("&d",&p->nomer);
Да, с чего бы это, может быть дело в спецификаторе?)
Не, со спецификатором все ок. Ведь все остальные работают.
0
 Аватар для Mecid
684 / 233 / 16
Регистрация: 15.10.2007
Сообщений: 1,246
29.04.2009, 23:14
посмори на переполнение и вводи так scanf("%d",&p->nomer);
0
 Аватар для FlamedoFF
0 / 0 / 0
Регистрация: 17.08.2008
Сообщений: 14
29.04.2009, 23:20  [ТС]
Цитата Сообщение от NickA Посмотреть сообщение
Код C++1
2
3
4
5
6
7
8
9
10
11
void vvod(abonent*p)
{
printf("Lastname:\n");
scanf("%s",p->familiya);

printf("Number:\n");
scanf("&d",&p->nomer);

printf("Year:\n");
scanf("%d",&p->year[4]);
}

Код C++1
scanf("&d",&p->nomer);
А & вместо % это нормально?

Спасибо. В этом все и дело.
Очень мелко, я не замечал.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.04.2009, 23:20
Помогаю со студенческими работами здесь

Ошибка "Память не может быть read"
При вводе кол-ва учеников больше 2 ух выдаёт после ввода такую ошибку. Вот код: #include &quot;stdafx.h&quot; #include &lt;conio.h&gt; ...

инструкция по адресу 0x7c91ac4a обратилась к памяти по адресу 0x00000010.Память не может быть written
Помогите разобраться пожалуйста!!!!! С:/rsit info.txt logfile of random's system information tool 1.06 2010-05-27 22:37:54 ...

Память не может быть read
При попытке обьявить кнопку или лейбл в виджете в заголовочном файле класса(QPushButton *btn), а далее в конструкторе(btn = new...

Память не может быть read. GDI
Здравствуйте. Пишу программу по работе с фото. Нашел функцию для преобразования цветной картинки в черно-белую эта функция вызывается в...

Ошибка: память не может быть read
При инициализации глобального массива появляется ошибка: Инструкция по адресу &quot;***&quot; обратилась к памяти по адресу...


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

Или воспользуйтесь поиском по форуму:
24
Ответ Создать тему
Новые блоги и статьи
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru