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

Затруднение в правильности написания кода

25.04.2018, 13:41. Показов 731. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пожалуйста, помогите решить проблему. Много вариантов перепробовала, ничего особо не получалось, так что решила обратиться за помощью сюда. Заранее благодарю.
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
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.SqlClient;
 
namespace TestPDD_v2._0
 
{
    public partial class Form1 : Form
    {
        int kolvo_voprosov, praviln_otvetov, nepraviln_otvetov,k;
        string[,] questionnansver;
        string connectionString = @"Data Source=.\SQLEXPRESS;Initial Catalog=testPdd;Integrated Security=True";
        string sqlExpression = "SELECT * FROM TestPdd";
        static Random rand = new Random();
 
 
        public Form1()
        {
            InitializeComponent();
            init_test();
        }
 
        public void init_test()
        {
            button_next.Text = "Следующий вопрос";
            kolvo_voprosov = 5;
            praviln_otvetov = 0;
            nepraviln_otvetov = 0;
            radio_cheked();
            radio_turn_on_off();
            label_result.Text = "";
            kolvo_voprosov--;
            show_question();
            textBox1.Visible = false;
            label1.Visible = false;
            label_question.Visible = true;
            textBox1.Text = "";
            string[,] questionnansver = new string[5,4];
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                connection.Open();
                SqlCommand command = new SqlCommand(sqlExpression, connection);
                SqlDataReader reader = command.ExecuteReader();
                {
                    for( int i=1; reader.Read()!=false; i++)
                    {
                        string question = Convert.ToString(reader.GetValue(1));
                        string ranswer = Convert.ToString(reader.GetValue(2));
                        string answer2 = Convert.ToString(reader.GetValue(3));
                        string answer3 = Convert.ToString(reader.GetValue(4));
                        string answer4 = Convert.ToString(reader.GetValue(5));
                        questionnansver[i, 0] = question;
                        questionnansver[i, 1] = ranswer;
                        questionnansver[i, 2] = answer2;
                        questionnansver[i, 3] = answer3;
                        questionnansver[i, 4] = answer4;
                    }
                }
                connection.Close();
            }
        }
 
        private void show_question()
        {
 
            radio_turn_on_off();
            radio_cheked();
            k = rand.Next(1,6);
            label_question.Text = questionnansver[k,0];
            radio_tags(rand.Next(1, 25));
            radioButton1.Text = questionnansver[k, Convert.ToInt16(radioButton1.Tag)];
            radioButton2.Text = questionnansver[k, Convert.ToInt16(radioButton2.Tag)];
            radioButton3.Text = questionnansver[k, Convert.ToInt16(radioButton3.Tag)];
            radioButton4.Text = questionnansver[k, Convert.ToInt16(radioButton4.Tag)];
        }
        private void Form1_Load(object sender, EventArgs e)
        {
 
        }
        private void button_next_Click(object sender, EventArgs e)
        {
            if (kolvo_voprosov < 0)
            {
                init_test();
                return;
            }
            textBox1.Text = "";
            textBox1.Visible = false;
            if (!(radioButton1.Checked || radioButton2.Checked || radioButton3.Checked || radioButton4.Checked))
            {
                MessageBox.Show("Выберите вариант ответа!");
                return;
            }
            if ((radioButton1.Checked && Convert.ToInt16(radioButton1.Tag) == 1) || (radioButton2.Checked && Convert.ToInt16(radioButton2.Tag) == 1) || (radioButton3.Checked && Convert.ToInt16(radioButton3.Tag) == 1) || (radioButton4.Checked && Convert.ToInt16(radioButton4.Tag) == 1))
            {
                praviln_otvetov++;
                kolvo_voprosov--;
            }
            else
            {
                MessageBox.Show("Правильный вариант ответа: " + questionnansver[k, 1]);
                nepraviln_otvetov++;
                kolvo_voprosov--;
            }
            if (kolvo_voprosov < 0)
            {
                show_result();
                label_question.Visible = false;
                label1.Visible = true;
                button_next.Text = "Начать тест заново";
                radio_turn_on_off();
                return;
            }
            show_question();
        }
        private void radio_turn_on_off()
        {
            if (kolvo_voprosov < 0)
            {
                radioButton1.Visible = false;
                radioButton2.Visible = false;
                radioButton3.Visible = false;
                radioButton4.Visible = false;
                textBox1.Visible = false;
            }
            else
            {
                radioButton1.Visible = true;
                radioButton2.Visible = true;
                radioButton3.Visible = true;
                radioButton4.Visible = true;
            }
        }
        private void radio_cheked()
        {
            radioButton1.Checked = false;
            radioButton2.Checked = false;
            radioButton3.Checked = false;
            radioButton4.Checked = false;
        }
        private void radio_tags(int i)
        {
            switch (i)
            {
                case 1: radioButton1.Tag = 1; radioButton2.Tag = 2; radioButton3.Tag = 3; radioButton4.Tag = 4; break;
                case 2: radioButton1.Tag = 1; radioButton2.Tag = 2; radioButton3.Tag = 4; radioButton4.Tag = 3; break;
                case 3: radioButton1.Tag = 1; radioButton2.Tag = 3; radioButton3.Tag = 2; radioButton4.Tag = 4; break;
                case 4: radioButton1.Tag = 1; radioButton2.Tag = 3; radioButton3.Tag = 4; radioButton4.Tag = 2; break;
                case 5: radioButton1.Tag = 1; radioButton2.Tag = 4; radioButton3.Tag = 2; radioButton4.Tag = 3; break;
                case 6: radioButton1.Tag = 1; radioButton2.Tag = 4; radioButton3.Tag = 3; radioButton4.Tag = 2; break;
                case 7: radioButton1.Tag = 2; radioButton2.Tag = 1; radioButton3.Tag = 3; radioButton4.Tag = 4; break;
                case 8: radioButton1.Tag = 2; radioButton2.Tag = 1; radioButton3.Tag = 4; radioButton4.Tag = 3; break;
                case 9: radioButton1.Tag = 2; radioButton2.Tag = 3; radioButton3.Tag = 1; radioButton4.Tag = 4; break;
                case 10: radioButton1.Tag = 2; radioButton2.Tag = 3; radioButton3.Tag = 4; radioButton4.Tag = 1; break;
                case 11: radioButton1.Tag = 2; radioButton2.Tag = 4; radioButton3.Tag = 1; radioButton4.Tag = 3; break;
                case 12: radioButton1.Tag = 2; radioButton2.Tag = 4; radioButton3.Tag = 3; radioButton4.Tag = 1; break;
                case 13: radioButton1.Tag = 3; radioButton2.Tag = 1; radioButton3.Tag = 2; radioButton4.Tag = 4; break;
                case 14: radioButton1.Tag = 3; radioButton2.Tag = 1; radioButton3.Tag = 4; radioButton4.Tag = 2; break;
                case 15: radioButton1.Tag = 3; radioButton2.Tag = 2; radioButton3.Tag = 1; radioButton4.Tag = 4; break;
                case 16: radioButton1.Tag = 3; radioButton2.Tag = 2; radioButton3.Tag = 4; radioButton4.Tag = 1; break;
                case 17: radioButton1.Tag = 3; radioButton2.Tag = 4; radioButton3.Tag = 1; radioButton4.Tag = 2; break;
                case 18: radioButton1.Tag = 3; radioButton2.Tag = 4; radioButton3.Tag = 2; radioButton4.Tag = 1; break;
                case 19: radioButton1.Tag = 4; radioButton2.Tag = 1; radioButton3.Tag = 2; radioButton4.Tag = 3; break;
                case 20: radioButton1.Tag = 4; radioButton2.Tag = 1; radioButton3.Tag = 3; radioButton4.Tag = 2; break;
                case 21: radioButton1.Tag = 4; radioButton2.Tag = 2; radioButton3.Tag = 1; radioButton4.Tag = 3; break;
                case 22: radioButton1.Tag = 4; radioButton2.Tag = 2; radioButton3.Tag = 3; radioButton4.Tag = 1; break;
                case 23: radioButton1.Tag = 4; radioButton2.Tag = 3; radioButton3.Tag = 1; radioButton4.Tag = 2; break;
                case 24: radioButton1.Tag = 4; radioButton2.Tag = 3; radioButton3.Tag = 2; radioButton4.Tag = 1; break;
            }
        }
        private void show_result()
        {
            label_result.Text = "Правильных ответов: " + praviln_otvetov.ToString() + "\nНеправильных ответов: " + nepraviln_otvetov.ToString();
        }
    }
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.04.2018, 13:41
Ответы с готовыми решениями:

Оценка правильности написания кода
Вечер добрый. В учебных целях написал программу которая переводит значение угла из вида 11.0° 49.0′ 12.6″ в вид 11,82017, а...

Небольшой шаблонный класс matrix: комментарии/критика относительно кода с точки зрения правильности написания
В плане своего общего развития написал не большой шаблонный класс matrix. Хочу поделиться своей работой с остальными, - может кому то это...

о правильности написания
Всем привет! Есть неясности: Имеем функцию: void foo(int* i); Как правильнее ее описать и вызывать? В книгах выдел 2...

9
Эксперт .NET
 Аватар для Usaga
14073 / 9290 / 1347
Регистрация: 21.01.2016
Сообщений: 34,877
25.04.2018, 13:43
Walkiria, а проблема в чём? Или нам её угадать надо?
0
0 / 0 / 0
Регистрация: 21.08.2017
Сообщений: 15
25.04.2018, 16:27  [ТС]
Ой, я извиняюсь. Проблема в том, что программа не видит массива. А ошибку выделяет в этой строке:
C#
1
label_question.Text = questionnansver[k,0];
Ссылка на объект не указывает на экземпляр объекта
0
Эксперт .NET
 Аватар для Usaga
14073 / 9290 / 1347
Регистрация: 21.01.2016
Сообщений: 34,877
25.04.2018, 16:50
Walkiria, это не обязательно относится к массиву, это может значить, что и label_question равен null.

Вы изучали работу своего кода с помощью отладчика (debugger)?
0
0 / 0 / 0
Регистрация: 21.08.2017
Сообщений: 15
25.04.2018, 16:58  [ТС]
Не могли бы вы мне рассказать, что из себя представляет отладчик?
0
Эксперт .NET
 Аватар для Usaga
14073 / 9290 / 1347
Регистрация: 21.01.2016
Сообщений: 34,877
25.04.2018, 17:11
Walkiria, это встроенный в студию инструмент анализа работы приложения. На ютюбе полно видосов на эту тему.
1
0 / 0 / 0
Регистрация: 21.08.2017
Сообщений: 15
27.04.2018, 11:30  [ТС]
Проблема заключается в том, что выдаёт ошибку, написанную в заголовке. Судя по отладчику, переменные считываются, а вот в массив не записываются из-за ошибки. Подскажите, в чём проблема.
C#
1
  string[,] questionnansver;
C#
1
string[,] questionnansver = new string[5,4];
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
 
using (SqlConnection connection = new SqlConnection(connectionString))
            {
                connection.Open();
                SqlCommand command = new SqlCommand(sqlExpression, connection);
                SqlDataReader reader = command.ExecuteReader();
                {
                    for (int i = 1; reader.Read() != false; i++)
                    {
                        string question = Convert.ToString(reader.GetValue(1));
                        string ranswer = Convert.ToString(reader.GetValue(2));
                        string answer2 = Convert.ToString(reader.GetValue(3));
                        string answer3 = Convert.ToString(reader.GetValue(4));
                        string answer4 = Convert.ToString(reader.GetValue(5));
                        questionnansver[i, 0] = question;
                        questionnansver[i, 1] = ranswer;
                        questionnansver[i, 2] = answer2;
                        questionnansver[i, 3] = answer3;
                        questionnansver[i, 4] = answer4;
                    }
                }
                connection.Close();
            }
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18234 / 14148 / 5366
Регистрация: 17.03.2014
Сообщений: 28,840
Записей в блоге: 1
27.04.2018, 12:17
Walkiria, исправь строку №45 в коде из первого сообщения на
C#
1
questionnansver = new string[5,4];
1
0 / 0 / 0
Регистрация: 21.08.2017
Сообщений: 15
27.04.2018, 14:45  [ТС]
Благодарю за поправку. Но, не подскажите ли вы мне, какие возможно перебрать варианты, что бы исправить ошибку.
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18234 / 14148 / 5366
Регистрация: 17.03.2014
Сообщений: 28,840
Записей в блоге: 1
27.04.2018, 23:30
Walkiria, какие варианты? "Поправка" должна убрать ошибку с NullReferenceException.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.04.2018, 23:30
Помогаю со студенческими работами здесь

Проверка правильности написания Жи Ши
Здравствуйте. Нужна помощь с задачкой: с клавиатуры вводится многострочный текст. Составить программу, которая проверяет правильность...

Вычисление правильности написания корней
Ребят помогите,в VB я новичок,а для зачета нужна программа... Правильность написания в русском языке слов с корнями бир/бер Принцип...

Проверка правильности написания программы
Подскажите пожалуйста правильно ли написан код этой программы? Имеется в виду не сами примеры что в case! double a, b, c, d, e, s, x, y,...

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

Проверка правильности написания матрицы
Написал проверку, вроде как рабочую, но проблема в том, что компилятор выдаёт предупреждение: обнаружен недостижимый код. Что в коде не...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru