Re: Lifetime of PQexecPrepared() returned value

From: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
To: Igor Korot <ikorot01(at)gmail(dot)com>
Cc: pgsql-general <pgsql-general(at)postgresql(dot)org>
Subject: Re: Lifetime of PQexecPrepared() returned value
Date: 2017-08-04 21:01:16
Message-ID: 19607.1501880476@sss.pgh.pa.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-general

Igor Korot <ikorot01(at)gmail(dot)com> writes:
> I have a following piece of code:

> [code]
> PGresult *res = PQexecPrepared();
> status = PQresultStatue( res );
> if( status == PGRES_TUPLES_OK )
> {
> for( int j = 0; j < PQntuples( res ); j++ )
> {
> char *foo = PQgetValue( res, j, 0 );
> char *bar = PQgetValue( res, j, 1 );
> MyObject *obj = new MyObject( foo, bar );
> if( SetAdditionalProperties( obj ) )
> {
> result = 1;
> break;
> }
> }
> PQclear( res );
> }

What I'm wondering about is whether the MyObject constructor is making
copies of the strings it's passed, or whether it thinks it can just hold
onto those pointers. The pointers would be dangling once you do PQclear.
Now, if the MyObject has gone out of scope and been destroyed, which
this coding suggests would happen, then that shouldn't matter ... but
maybe the pointers got copied to somewhere longer-lived? Anyway, there's
nothing visibly wrong with what you showed us, so the problem is somewhere
else.

regards, tom lane

In response to

Responses

Browse pgsql-general by date

  From Date Subject
Next Message Alexander Farber 2017-08-05 15:58:23 Type cast in PHP PDO (does not work like in Java?)
Previous Message Igor Korot 2017-08-04 19:29:19 Re: Lifetime of PQexecPrepared() returned value