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

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

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 19, средняя оценка - 4.68
Bogdan30637
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
27.06.2012, 14:32     Передача массива структур в функцию не указывая размера массива #1
Я читаю с командной строки файл в котором содержится массив структур. Есть библиотека с функцией в которую я прередаю файл и массив структур, в который запишется содержимое файла. Вопрос: как предать этот массив не указывая его размера?

код библиотеки:
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;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.06.2012, 14:32     Передача массива структур в функцию не указывая размера массива
Посмотрите здесь:

передача многомерного массива переменного размера в функцию C++
Передача массива структур в функцию C++
C++ Передача динамического массива структур в функцию
C++ Передача массива структур
Нахождение размера массива структур C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
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";
тогда последнюю найти будет не проблемно.
Я не понял как это поможет в решении моей проблемы?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
villu
202 / 202 / 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
Bogdan30637
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
02.07.2012, 13:21  [ТС]     Передача массива структур в функцию не указывая размера массива #23
Спасибо за подсказку, но у меня массив структур инициализируется в функции, в которую мне нужно передать его не зная размера, по скольку размер зависит от количества строк файла, работа с которым выполняется в функции.
villu
202 / 202 / 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 ));
но лучше передавай размер. Просто меньше лишней работы будет.
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;
}
Пробовал создать программу исключительно с вашим кодом - работает. Где напартачил понять не могу.
tabber
 Аватар для tabber
20 / 37 / 1
Регистрация: 10.10.2010
Сообщений: 364
02.07.2012, 16:29     Передача массива структур в функцию не указывая размера массива #26
в функцию передается сылка и поэтому размер неизвестен
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;
}
villu
202 / 202 / 4
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
02.07.2012, 16:38     Передача массива структур в функцию не указывая размера массива #28
а без вызова (*reader)(argc[1],somedata); работает?
если да, то смотри что в этой функции происходит.
Bogdan30637
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
02.07.2012, 16:50  [ТС]     Передача массива структур в функцию не указывая размера массива #29
И без вызова не работает.
villu
202 / 202 / 4
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
02.07.2012, 17:17     Передача массива структур в функцию не указывая размера массива #30
а я понял ...
я накосячил

C
1
test = (struct data *)malloc(sizeof(struct data) * 100 + 1);
пробуй так.
Bogdan30637
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

не пойму к чему бы это
villu
202 / 202 / 4
Регистрация: 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");
Bogdan30637
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
03.07.2012, 12:17  [ТС]     Передача массива структур в функцию не указывая размера массива #33
villu, огромное спасибо за помощь!
villu
202 / 202 / 4
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
03.07.2012, 13:58     Передача массива структур в функцию не указывая размера массива #34
поправь тогде еще тут, если не заметил
C
1
test = (struct data *)malloc(sizeof(struct data) * (100 + 1));

Не по теме:

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

Bogdan30637
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) значения
villu
202 / 202 / 4
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
03.07.2012, 15:43     Передача массива структур в функцию не указывая размера массива #36
в заголовке тоже изменил? ну или там, где у тебя эта функция объявляется?
CheshireCat
Эксперт С++
2907 / 1235 / 78
Регистрация: 27.05.2008
Сообщений: 3,309
03.07.2012, 15:46     Передача массива структур в функцию не указывая размера массива #37
Очень просто:
C++
1
2
#include <vector>
void reader(const char filename[], std::vector<data>& somedata)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.07.2012, 16:00     Передача массива структур в функцию не указывая размера массива
Еще ссылки по теме:

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

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

Или воспользуйтесь поиском по форуму:
Bogdan30637
0 / 0 / 0
Регистрация: 27.06.2012
Сообщений: 17
03.07.2012, 16:00  [ТС]     Передача массива структур в функцию не указывая размера массива #38
Цитата Сообщение от villu Посмотреть сообщение
в заголовке тоже изменил? ну или там, где у тебя эта функция объявляется?
фух, спасибо, что-то я завтыкал
Yandex
Объявления
03.07.2012, 16:00     Передача массива структур в функцию не указывая размера массива
Ответ Создать тему
Опции темы

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