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

Почему появляются дополнительный сиволы в строке? - C++

Восстановить пароль Регистрация
 
Darthriddikc
10 / 10 / 0
Регистрация: 23.12.2012
Сообщений: 45
14.10.2013, 00:58     Почему появляются дополнительный сиволы в строке? #1
Относительно недавно начал изучать C++, дошёл до структур, написал код:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <iostream>
#include <string.h>
using namespace std;
struct test1
{
    int num1;
    char str1[8];
}obj1[10];
void main()
{
    int i;
    for (i=0; i<3; i++)
    {
        obj1[i].num1=i;
        strcpy(obj1[i].str1,"qwertyui");
    }
    for (i=0; i<3; i++)
        cout<<obj1[i].num1<<' '<<obj1[i].str1<<endl;
}
Вывод программы в прикреплённом изображении. Почему у str1 появляются лишние символы в конце, причём я заметил, что это как-то зависит от значения num1; в зависимости от его значения лишних символов больше и/или другие, проверил, что с адресами вроде всё в порядке, а если str1[8]; объявить раньше чем num1, т.е.:

C++
1
2
3
4
5
struct test1
{
    char str1[8];
    int num1;
}obj1[10];
то все значения num1 равны 0
В общем в чём прикол, или я слепой и чего-то в упор не вижу?)
Миниатюры
Почему появляются дополнительный сиволы в строке?  
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Max Dark
В поиске работы
 Аватар для Max Dark
1546 / 1399 / 501
Регистрация: 09.10.2013
Сообщений: 3,185
Записей в блоге: 8
Завершенные тесты: 2
14.10.2013, 01:05     Почему появляются дополнительный сиволы в строке? #2
Строка должна оканчиваться символом '\0'
те длина результата должна быть больше длины копируемой строки минимум на единицу
У вас происходит переполнение длины результата
kventin_zhuk
БНТУ ФИТР
 Аватар для kventin_zhuk
214 / 154 / 15
Регистрация: 26.12.2012
Сообщений: 382
14.10.2013, 01:07     Почему появляются дополнительный сиволы в строке? #3
Darthriddikc, у вас массив из 8-ми символов, но строки по представлению си должны заканчиваться так называемым нуль-символов. А у вас под него места нет так что если хотите массив из 8 символов, зарезервируйте память под 9 элементов. Поэтому у вас и выводит всякие нечистоты - пока до нуль-символа не дойдет.

Добавлено через 56 секунд
Cra3y, шустро
MrGluck
Ворчун
Эксперт С++
 Аватар для MrGluck
4919 / 2662 / 243
Регистрация: 29.11.2010
Сообщений: 7,399
14.10.2013, 01:11     Почему появляются дополнительный сиволы в строке? #4
Darthriddikc, проблема в том, что в символьном массиве char на конце идет '\0' завершающий символ, который сигнализирует о конце строкового литерала. Вам следовало бы задать размер str1 как > 9 (вообще, что за скупость с памятью?)

Я также советую вам не использовать глобальные переменные (у вас они объявляются сразу после структуры) и для main ставить идентификатор типа возвращаемого значения как int, т.к. этого (последнее) требует стандарт.
Darthriddikc
10 / 10 / 0
Регистрация: 23.12.2012
Сообщений: 45
14.10.2013, 02:30  [ТС]     Почему появляются дополнительный сиволы в строке? #5
Точно! Совсем вылетело из головы, что при объявления массива str1[8] элементы у него от 0 до 7 а не до 8, спасибо всем за объяснения)

но тут я заметил закономерность, что, если объявить char str1[9]; и присвоить аналогично, только 9 символов (например:"qwertyuio"), то такой проблемы нет, и с char str1[10];, если провести аналогичные действия с 10-ю символами, тоже проблем нет, и с char str1[11]; также. А вот если объявить char str1[12]; и присвоить 12 символов появляются те же проблемы с переполнением, а потом также начиная с char str1[13]; до char str1[15]; всё нормально "жуётся", но char str1[16] ненормально и т.д. и т.п.
В общем переполнение возникает на всех массивах с числом элементов кратных 4, а 4 - это длина типа int в байтах, которым и объявлен num1, плюс если у всех элементов объекта obg1 переменная num1 будет 0, то переполнение у массива str1 ни при каком количестве элементов не будет, тут явно какая-то связь Так вот) я хочу понять почему так происходит и что это за связь) это как-то относится к специфическому распределении памяти у структуры? И ещё, почему значения после присваивании num1 обнуляются, если поменять местами объявления в структуре и если количество элементов у str1 кратно 4?
AnyOne697
 Аватар для AnyOne697
134 / 106 / 5
Регистрация: 22.05.2010
Сообщений: 532
14.10.2013, 02:53     Почему появляются дополнительный сиволы в строке? #6
Цитата Сообщение от Darthriddikc Посмотреть сообщение
но тут я заметил закономерность
Потому что структуры по умолчанию выравниваются по длине слова, которое на 32х битных процессорах равно 4. Впрочем, сегодня это обычно зависит от компилятора, а не архитектуры.
MrGluck
Ворчун
Эксперт С++
 Аватар для MrGluck
4919 / 2662 / 243
Регистрация: 29.11.2010
Сообщений: 7,399
14.10.2013, 02:56     Почему появляются дополнительный сиволы в строке? #7
Можете почитать про выравнивание полей в структуре, но вот то, что
Цитата Сообщение от Darthriddikc Посмотреть сообщение
4 - это длина типа int в байтах
это вы ошибайтесь. По стандарту количество байт под int не определено и может отличаться на разных платформах.

А вот это
Цитата Сообщение от Darthriddikc Посмотреть сообщение
почему значения после присваивании num1 обнуляются, если поменять местами объявления в структуре и если количество элементов у str1 кратно 4?
не понял. Что вы имели в виду?

Добавлено через 58 секунд

Не по теме:

А вы молодец, не каждый сам практически догадывается до выравнивания полей.

AnyOne697
 Аватар для AnyOne697
134 / 106 / 5
Регистрация: 22.05.2010
Сообщений: 532
14.10.2013, 03:02     Почему появляются дополнительный сиволы в строке? #8
Цитата Сообщение от Darthriddikc Посмотреть сообщение
И ещё, почему значения после присваивании num1 обнуляются, если поменять местами объявления в структуре и если количество элементов у str1 кратно 4
Всё из-за того, что Вы используете strcpy, а он не знает о размере выделенной памяти, а копирует всю строку, включая последний нуль. Вообще, в любом самоучителе по Си (и даже по плюсам) написано, что константные строки нуль терминированные (заканчиваются нуль-символом). Структура же - банальный массив, просто с более удобным вычислением сдвигов по нему.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.10.2013, 03:19     Почему появляются дополнительный сиволы в строке?
Еще ссылки по теме:

Почему в конце символьной строки появляются разные символы, и что с ними делать? C++
C++ дополнительный счетчик не считает
C++ Почему при запуске программы в командной строке иероглифы

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

Или воспользуйтесь поиском по форуму:
Darthriddikc
10 / 10 / 0
Регистрация: 23.12.2012
Сообщений: 45
14.10.2013, 03:19  [ТС]     Почему появляются дополнительный сиволы в строке? #9
Цитата Сообщение от MrGluck Посмотреть сообщение
не понял. Что вы имели в виду?
Ну если написать мой код, который я написал в 1 сообщении, но объявить сначала char str1[8];, а потом int num1;, т.е.:

C++
1
2
3
4
5
struct test1
{
    char str1[8];
    int num1;
}
то при выводе у меня все значения num1 равнялись 0
Yandex
Объявления
14.10.2013, 03:19     Почему появляются дополнительный сиволы в строке?
Ответ Создать тему
Опции темы

Текущее время: 10:44. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru