mysql c api 를 이용한 wrapping 라이브러리

idrukawa의 이미지

안녕하세요.

c api를 wrapping 해서 db 라이브러리를 만들어 보려고 합니다.

간략하게 이렇게 작성을 했는데요.

int do_connect(MYSQL *conn_out, ip, id, pw, db_name, port, sock, flag)
{
  printf( "conn_out: %p\n", conn_out );
  conn_out = mysql_init (NULL);
  if( conn_out == NULL )
    return -1;
 
  if( mysql_real_connect(conn_out, ip, id, pw, db_name, port, sock, flag) == NULL )
    return -1;
 
  printf( "conn_out: %p\n", conn_out );
  return 0;
}

main에서 확인을 해보면 첫번째 인자값에 connect 포인터가 넘어오기를 기대했지만 계속 NULL로 남아있습니다.
왜그런지 알려주세요~

int main()
{
  MYSQL *conn = NULL;
  printf( "conn: %p\n", conn );
 
  if( do_connect( conn, ip, id, pw, db_name, port, sock, flag) < 0 )
    exit(0);
 
  printf( "conn: %p\n", conn );
}

print 결과가
첫번째는 main() 쪽에서 NULL
두번째는 do_connect() 에서 NULL
세번째는 do_connect() 에서 유효한 포인터
네번째는 main() 에서 NULL
로 찍히네요.

do_connect() 첫번째인자로 포인터를 줬는데도 값이 넘어오지 않는건 왜그런 걸까요?

idrukawa의 이미지

그런데 다음과 같이 return을 MYSQL * 로 하면 제대로 connect 포인터가 넘어오네요.

MYSQL *do_connect (ip, id, pw, db_name, port, socket, flag)
{
    MYSQL *conn; /* pointer to connection handler */
 
    conn = mysql_init (NULL); /* allocate, initialize connection handler */
    if (conn == NULL)
        return (NULL);
    if (mysql_real_connect (conn, ip, id, pw, db_name, port, socket, flag) == NULL)
        return (NULL);
 
    return (conn); /* connection is established */}

main에서는

int main()
{
  MYSQL *conn=NULL;
  conn = do_connect(ip, id, pw, db_name, port, socket, flag);
}

이런 식으로 return으로 mysql connect 포인터를 반환하면 정상적으로 넘어옵니다.
차이를 잘 모르겠네요...

익명 사용자의 이미지

conn = NULL;

do_connect 함수 호출 직후
conn = NULL;
conn_out = NULL;

mysql_init 함수 호출 후
conn = NULL;
conn_out = somewhere;

parameter 로 conn 포인터를 넘겨 줄 때 자신이 가르키고 있는 주소를 argument 로 넘겨 준 것이지 pointer 자신을 넘겨준 것이 아니기 때문에 conn_out 이 처음에는 conn과 같은 곳을 바라보지만 mysql_init 에서 메모리를 할당하고 그 주소 값을 넘겨 받게 되면 서로 다른 곳을 바라보게 됩니다.

익명 사용자의 이미지

conn을 변경시키기 원하면 conn의 주소를 넘겨주셔야죠.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.