Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 19, средняя оценка - 4.68
Bogdan30637
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
#1

Передача массива структур в функцию не указывая размера массива - C++

27.06.2012, 14:32. Просмотров 2726. Ответов 37
Метки нет (Все метки)

Я читаю с командной строки файл в котором содержится массив структур. Есть библиотека с функцией в которую я прередаю файл и массив структур, в который запишется содержимое файла. Вопрос: как предать этот массив не указывая его размера?

код библиотеки:
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define N 4
 
struct data
{
    char key[50];
    char value[50];
};
void reader(const char filename[],struct data somedata[]){
    FILE* file=fopen(filename,"r");
    memset(somedata,0,(sizeof(somedata[N]))*N);
    int i=0;
    for(i=0;i<N;i++){
        fscanf(file,"%s %s",somedata[i].key,somedata[i].value);
    }
    fclose(file);
    for(i=0;i < N;i++)
    {
        puts(somedata[i].key);
        puts(somedata[i].value);
    }
}
основной код:
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <dlfcn.h>
#define N 4
 
struct data
{
    char key[50];
    char value[50];
} somedata[N];
 
typedef void (*td_reader)(const char[20], struct data somedata[N]);
 
int main(int argv, char* argc[]){
    if (argv!=2){
        printf("You shood enter file's name.\n");
        return 0;
    }
    void *handle=dlopen("libfilereader.so",RTLD_LAZY);
    if(handle==0){
        printf("Library didn't found.");
    }
    td_reader reader=(td_reader)dlsym(handle,"reader");
    printf("%d %d\n",sizeof(argc[1]),sizeof(&somedata[N]));
    (*reader)(argc[1],&somedata[N]);
    dlclose(handle);
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.06.2012, 14:32
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Передача массива структур в функцию не указывая размера массива (C++):

Передача массива структур в функцию - C++
В общем проблема с передачей массива структур в функцию... Структура описана следующим образом: struct struct_write { char Name; ...

Передача массива структур в функцию - C++
Помогите пожалуйста исправить ошибку. Массив student std должен передаваться в функции.VS 2010 ошибок не выдаёт , программа запускается,...

Передача динамического массива структур в функцию - C++
Доброго времени суток:) Имеется входной файл,который представлен в виде пар через запятую (010)-(110),(001)-(100),... надо загнать его...

Передача динамического массива структур в функцию - C++
Помогите, пожалуйста переделать. Нужно передать динамический массив. Есть такой код: #include&lt;iostream&gt; using namespace std; void...

Передача массива структур в функцию через указатель - C++
вот пример куска кода, не могу понять почему ругается на: void Add(student *ptr) { for(int i = 0; i&lt;lim; i++) { ...

Передача многомерного массива переменного размера в функцию - C++
Как в с передается в функцию многомерный массив, чья размерность определеяется &quot;по ходу дела&quot;. Вариант в фортране: ... call...

37
Bogdan30637
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
02.07.2012, 11:09  [ТС] #16
Цитата Сообщение от remarkes Посмотреть сообщение
Bogdan30637, как передать массив, не указывая размера? - ответ - никак
Спасибо за конкретный ответ.
0
remarkes
303 / 226 / 13
Регистрация: 01.07.2011
Сообщений: 809
Записей в блоге: 1
02.07.2012, 11:13 #17
Bogdan30637, хотел добавить одну концептуальную вещь, на которой даже в учебниках не всегда акцентируют внимание. Когда мы вызываем функцию, мы передаем копии наших аргументов. Если мы передаем указатель, то мы также передаем копию адреса. А не оригинал.
В стандарте C99 стало возможным передавать именно копии массивов, таким образом стало возможным передать в функцию динамический массив (массив переменной длины), но опять же - для того чтобы передать копию массива целиком, необходимо передать его размер. То есть вычисления размера длины массива должны происходить не в вызываемой функции, а до нее.
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <stdio.h>
 
void func(int n, int array[n]) {
    int i;
    for (i = 0; i < n; i++){
        printf("%i\n", array[i]);
    }
}
 
int main(void) {
    int b[3] = {1, 2, 3};
    int c[5] = {6, 7, 8};
    func(3, b);
 
    func(5, c);
    func(2, c);
 
    return 0;
}
На самом деле это не больно
sizeof(array)/sizeof(array[0])

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <stdio.h>
 
void func(int n, int array[n]) {
    int i;
    for (i = 0; i < n; i++){
        printf("%i\n", array[i]);
    }
}
 
int main(void) {
    int b[3] = {1, 2, 3};
    int c[5] = {6, 7, 8};
    func(sizeof(b)/sizeof(b[0]), b);
    func(sizeof(c)/sizeof(c[0]), c);
 
    return 0;
}
0
kent
Нуб со стажем
36 / 34 / 2
Регистрация: 19.02.2012
Сообщений: 118
02.07.2012, 11:16 #18
Цитата Сообщение от Bogdan30637 Посмотреть сообщение
как предать массив структур в функцию, не указывая его размера?
использовать шаблон vector
0
remarkes
303 / 226 / 13
Регистрация: 01.07.2011
Сообщений: 809
Записей в блоге: 1
02.07.2012, 11:29 #19
Цитата Сообщение от kent Посмотреть сообщение
использовать шаблон vector
я полагал, что судя по его коду имелся в виду Си, а не Си плюс плюс.
но в целом, vector - это да - решение.
0
villu
203 / 204 / 4
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
02.07.2012, 11:37 #20
еще вариант - передавать последней структурой нулевую.
например, если в структуре не может быть пустых ключей, то последняя может быть такой
C++
1
2
s.key = "\0";
s.value = "\0";
тогда последнюю найти будет не проблемно.
1
Bogdan30637
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
02.07.2012, 11:58  [ТС] #21
А входит ли векор в стандарты ANSI? Потому что программа должна быть кросплатформенной.


Цитата Сообщение от villu Посмотреть сообщение
еще вариант - передавать последней структурой нулевую.
например, если в структуре не может быть пустых ключей, то последняя может быть такой

C++
1
2
s.key = "\0";
s.value = "\0";
тогда последнюю найти будет не проблемно.
Я не понял как это поможет в решении моей проблемы?
0
villu
203 / 204 / 4
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
02.07.2012, 12:29 #22
подсказка
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
#include <stdio.h>
 
struct data {
    char key[20];
    char value[50];
};
 
size_t struct_count( struct data s[] ) {
    struct data *p = s;
    size_t count = 0;
    if( p != NULL) while (*p->key) {
        p++; count++;
    };
    return count;
}
 
int main()
{
    struct data s1[] = {
        {"1", "value 1"},
        {"2", "value 2"},
        {"3", "value 3"},
        {"4", "value 4"},
        {"5", "value 5"},
        {"6", "value 6"},
        {"", ""},
    };
    struct data s2[] = {
        {"", ""},
    };
    printf("s1.count = %d\n", struct_count( s1 ));
    printf("s2.count = %d\n", struct_count( s2 ));
    return 0;
}
s1.count = 6
s2.count = 0
1
Bogdan30637
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
02.07.2012, 13:21  [ТС] #23
Спасибо за подсказку, но у меня массив структур инициализируется в функции, в которую мне нужно передать его не зная размера, по скольку размер зависит от количества строк файла, работа с которым выполняется в функции.
0
villu
203 / 204 / 4
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
02.07.2012, 13:29 #24
ну так это тоже не проблема ...
если ты пошел по пути "не передачи размера", а передаешь просто кусок памяти, то он должен быть заполнен соответственно.

Можно забить память пробелами, а в последней выставить в ключе первым ноль.
C
1
2
3
4
5
6
    struct data *test;
    test = (struct data *)malloc(100 + 1);
    memset( test, ' ', sizeof(struct data) * 100 );
    test[100].key[0] = 0;
 
    printf("test.count = %d\n", struct_count( test ));
но лучше передавай размер. Просто меньше лишней работы будет.
1
Bogdan30637
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
02.07.2012, 16:26  [ТС] #25
Идея отличная, но у меня в программе почему-то выдает ошибку сегментации(второй print не выдаёт):
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <dlfcn.h>
#define N 5
 
struct data{
    char key[50];
    char value[50];
};
 
size_t struct_count( struct data s[] ) {
    struct data *p = s;
    size_t count = 0;
    if( p != NULL) while (*p->key) {
        p++; count++;
    };
    return count;
}
 
typedef void (*td_reader)(const char[20], struct data somedata[N]);
 
int main(int argv, char* argc[]){
    if (argv!=2){
        printf("You shood enter file's name.\n");
        return 0;
    }
    void *handle=dlopen("libfilereader.so",RTLD_LAZY);
    if(handle==0){
        printf("Library didn't found.");
    }
    td_reader reader=(td_reader)dlsym(handle,"reader");
 
    struct data *somedata;
    somedata = (struct data *)malloc(100 + 1);
    memset( somedata, ' ', sizeof(struct data) * 100 );
    somedata[100].key[0] = 0;
    printf("test.count = %d\n", struct_count( somedata ));
    printf("*****************");
    (*reader)(argc[1],somedata);
    dlclose(handle);
    return 0;
}
Пробовал создать программу исключительно с вашим кодом - работает. Где напартачил понять не могу.
0
tabber
36 / 40 / 1
Регистрация: 10.10.2010
Сообщений: 364
02.07.2012, 16:29 #26
в функцию передается сылка и поэтому размер неизвестен
0
Bogdan30637
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
02.07.2012, 16:35  [ТС] #27
В struct_count?
Но здесь то работает без проблем:
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
#include <stdio.h>
#include <stdlib.h>
#include <string>
struct data {
    char key[20];
    char value[50];
};
 
size_t struct_count( struct data s[] ) {
    struct data *p = s;
    size_t count = 0;
    if( p != NULL) while (*p->key) {
        p++; count++;
    };
    return count;
}
 
int main()
{
    struct data *test;
    test = (struct data *)malloc(100 + 1);
    memset( test, ' ', sizeof(struct data) * 100 );
    test[100].key[0] = 0;
 
    printf("test.count = %d\n", struct_count( test ));
 
    struct data s1[] = {
        {"1", "value 1"},
        {"2", "value 2"},
        {"3", "value 3"},
        {"4", "value 4"},
        {"5", "value 5"},
        {"6", "value 6"},
        {"", ""},
    };
    struct data s2[] = {
        {"", ""},
    };
    printf("s1.count = %d\n", struct_count( s1 ));
    printf("s2.count = %d\n", struct_count( s2 ));
    return 0;
}
0
villu
203 / 204 / 4
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
02.07.2012, 16:38 #28
а без вызова (*reader)(argc[1],somedata); работает?
если да, то смотри что в этой функции происходит.
0
Bogdan30637
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
02.07.2012, 16:50  [ТС] #29
И без вызова не работает.
0
villu
203 / 204 / 4
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
02.07.2012, 17:17 #30
а я понял ...
я накосячил

C
1
test = (struct data *)malloc(sizeof(struct data) * 100 + 1);
пробуй так.
1
02.07.2012, 17:17
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.07.2012, 17:17
Привет! Вот еще темы с ответами:

Нахождение размера массива структур - C++
Пытаюсь создать массив с фразами, но не получается найти величину массива через strlen #include &lt;iostream&gt; #include &lt;string.h&gt; using...

Передача массива структур - C++
Имеется программа. #include &lt;iostream&gt; #include &lt;iomanip&gt; #include &lt;conio.h&gt; using namespace std; ...

Передача массива структур в функции - C++
Написал лабораторную работу, программа свои функции выполняет, но мне кажется, что можно что-то наколдовать с памятью. Подскажите, как...

Передача массива структур в заголовочные файлы - C++
Всем привет! Возникла проблема с использованием массива структур в многомодульной программе. Я создаю структуру и массив структур в файле...


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

Или воспользуйтесь поиском по форуму:
30
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru