как реализовать функцию PHP next () в C - PullRequest
1 голос
/ 09 марта 2012

Я пытаюсь реализовать next () функцию PHP в C. если у меня есть

В отличие от моей реализации, я хочу сделать эту работу с более одного пункта. Например:

если у меня есть два char * вроде:

char * a = "ac\0";
char * b = "bd\0";

и я звоню:

printf("%c", cgetnext(a));
printf("%c", cgetnext(b));
printf("%c", cgetnext(a));
printf("%c", cgetnext(b));

получает вывод как: abcd

но я получаю abab

вот мой код:

`#include <string.h>
#include <stdlib.h>

typedef struct 
{
    int pLocation;
    int myindex;
    int lastIndex;
}   POINTERINFORMATION;

int                 __myIndex               = 0;
int                 pointersLocationsLength = 0;
char                * temparr               = NULL;
POINTERINFORMATION  pointersLocations[256];


int 
    plAdd (int p)
    {
        if (pointersLocationsLength >= sizeof(pointersLocations)) {
            return -1;
        } else {
            pointersLocations[pointersLocationsLength].pLocation = p;
            pointersLocations[pointersLocationsLength].lastIndex = 0;
            pointersLocationsLength ++;
            return pointersLocationsLength;
        }
    }

int 
    getPointer (int p, POINTERINFORMATION * out)
    {
        int i;
        for (i = 0; i < pointersLocationsLength; i++)
        {
            if(pointersLocations[pointersLocationsLength].pLocation == p)
            {
                pointersLocations[i].myindex = i;
                *out = pointersLocations[i];
                return 1;
            }
        }

        return 0;
    }

void 
    getPointerIndex(char ** variable, int * val)
    {
        char * buf = malloc(256);
        if(sprintf(buf,"%p", &variable) > 0){
            *val = strtol(buf, NULL, 16 );
        } else {
            *val = -1;
        }
    }

int 
    inArrayOfPointers (int pointer) 
    {
        POINTERINFORMATION pi;
        return getPointer(pointer, &pi);

    }

char 
    cgetnext(char * arr) 
    {
        char * myarr; 
        const size_t size = sizeof(char *) + 1;
        int pof;

        myarr = malloc(size);
        getPointerIndex (&arr, &pof);

        if (inArrayOfPointers(pof)){
            POINTERINFORMATION pi;

            if (getPointer(pof, &pi))
            {
                myarr = (char *)*(int *)pi.pLocation;
                __myIndex = pi.lastIndex;
                ++pointersLocations[pi.myindex].myindex;
            } else {
                return 0;
            }

        } else {

            if (plAdd(pof) == -1) {
                printf(" CANNOT ADD ELEMENT TO ARRAY\n");
                exit(0);
            } else {
                myarr = arr;
                __myIndex = 0;
            }
        }

        if (strlen(myarr) == __myIndex) {
            return 0;
        } else  {
            temparr = malloc(size);
            temparr = strdup(myarr);

            return myarr[__myIndex];
        }
    }`

как это исправить? Различные решения для ее решения очень ценятся! Заранее спасибо.

1 Ответ

1 голос
/ 09 марта 2012

Если вас особенно интересуют char* "массивы", то простое решение может просто увеличить указатель. Обратите внимание, что при использовании динамически выделяемой памяти вам необходимо сохранить исходный указатель, чтобы освободить его. Эта же идея может быть использована и для других типов данных.

Это пример того, что я имею в виду. cgetnext здесь просто возвращает символ в текущей позиции в массиве и увеличивает указатель (который передается по адресу).

char cgetnext( char **p )
{
   assert( p != NULL );
   // check for end of string
   if ( **p == '\0' )
      return '\0';
   return *(*p)++;
}


int main( int argc, char* argv[] )
{
   char *a = "ac";
   char *b = "bd";

   printf( "%c", cgetnext(&a));
   printf( "%c", cgetnext(&b));
   printf( "%c", cgetnext(&a));
   printf( "%c", cgetnext(&b));

}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...