0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
1

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

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

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

код библиотеки:
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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
27.06.2012, 14:32
Ответы с готовыми решениями:

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

Передача массива структур в функцию
Хочу передать в функцию указатель на массив структур: #include &quot;stdafx.h&quot; #include &lt;iostream&gt;...

Передача массива структур в функцию
Есть следующие структуры: public struct Gorod { public bool Otgr; public...

Передача массива структур в функцию
У меня есть массив структур,функция SLVE,как передать массив структур в функцию? struct...

37
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
02.07.2012, 11:58  [ТС] 21
Author24 — интернет-сервис помощи студентам
А входит ли векор в стандарты ANSI? Потому что программа должна быть кросплатформенной.


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

C++
1
2
s.key = "\0";
s.value = "\0";
тогда последнюю найти будет не проблемно.
Я не понял как это поможет в решении моей проблемы?
0
204 / 205 / 16
Регистрация: 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
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
02.07.2012, 13:21  [ТС] 23
Спасибо за подсказку, но у меня массив структур инициализируется в функции, в которую мне нужно передать его не зная размера, по скольку размер зависит от количества строк файла, работа с которым выполняется в функции.
0
204 / 205 / 16
Регистрация: 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
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
37 / 41 / 3
Регистрация: 10.10.2010
Сообщений: 364
02.07.2012, 16:29 26
в функцию передается сылка и поэтому размер неизвестен
0
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
204 / 205 / 16
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
02.07.2012, 16:38 28
а без вызова (*reader)(argc[1],somedata); работает?
если да, то смотри что в этой функции происходит.
0
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
02.07.2012, 16:50  [ТС] 29
И без вызова не работает.
0
204 / 205 / 16
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
02.07.2012, 17:17 30
а я понял ...
я накосячил

C
1
test = (struct data *)malloc(sizeof(struct data) * 100 + 1);
пробуй так.
1
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
02.07.2012, 18:43  [ТС] 31
Работает!

Добавлено через 9 минут
Теперь одна проблема осталась:
когда вызываю функцию из библиотеки, а не из основного файла
C
1
2
3
void *handle=dlopen("libfilereader.so",RTLD_LAZY);
    td_reader counter=(td_reader)dlsym(handle,"struct_count");
    printf("test.count = %d\n", (*counter)( somedata ));
выдает:
main.cpp:38: ошибка: ошибка преобразования ‘data*’ в ‘const char*’ в argument passing

не пойму к чему бы это
0
204 / 205 / 16
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
02.07.2012, 20:13 32
потому что
C
1
(const char[20], struct data somedata[N]);
2 параметр указатель на data, а не char * как тут:
C
1
dlsym(handle,"struct_count");
1
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
03.07.2012, 12:17  [ТС] 33
villu, огромное спасибо за помощь!
0
204 / 205 / 16
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
03.07.2012, 13:58 34
поправь тогде еще тут, если не заметил
C
1
test = (struct data *)malloc(sizeof(struct data) * (100 + 1));

Не по теме:

отдыхать, однако, пора

0
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
03.07.2012, 14:58  [ТС] 35
Я изменил тип функции с void на struct data:
C
1
2
3
4
struct data* reader(const char filename[],struct data somedata[]){
   //some code  
   return somedata;
}
и когда я пытаюсь в мэйне присвоить возвращаемое структуре somedata
C
1
somedata=(*reader)(argc[1],somedata);
выскакивает такая вот ошибка:
ошибка: использование пустого (void) значения
0
204 / 205 / 16
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
03.07.2012, 15:43 36
в заголовке тоже изменил? ну или там, где у тебя эта функция объявляется?
1
Эксперт С++
2924 / 1274 / 114
Регистрация: 27.05.2008
Сообщений: 3,465
03.07.2012, 15:46 37
Очень просто:
C++
1
2
#include <vector>
void reader(const char filename[], std::vector<data>& somedata)
0
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
03.07.2012, 16:00  [ТС] 38
Цитата Сообщение от villu Посмотреть сообщение
в заголовке тоже изменил? ну или там, где у тебя эта функция объявляется?
фух, спасибо, что-то я завтыкал
0
03.07.2012, 16:00
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
03.07.2012, 16:00
Помогаю со студенческими работами здесь

Передача массива структур в функцию
День добрый, учусь работать с структурами. #include &quot;stdafx.h&quot; #include &lt;iostream&gt; using...

Передача массива структур в функцию
Здравствуйте, у меня есть функция принимающая в параметрах массив структур. Нашел код, максимально...

Передача массива структур в функцию
В общем проблема с передачей массива структур в функцию... Структура описана следующим образом:...

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


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru