Chinaunix首页 | 论坛 | 博客
  • 博客访问: 521694
  • 博文数量: 68
  • 博客积分: 2501
  • 博客等级: 大尉
  • 技术积分: 713
  • 用 户 组: 普通用户
  • 注册时间: 2009-12-07 17:49
个人简介

文章分类

全部博文(68)

分类: C/C++

2010-09-05 17:03:01

摘自
 
在将各种类型的数据构造成字符串时,sprintf 的强大功能很少会让你失望。由于sprintf 跟printf 在用法上几乎一样,只是打印的目的地不同而已,前者打印到字符串中,后者则直接在命令行上输出。这也导sprintf 比printf 有用得多。
 
sprintf 是个变参函数,定义如下:
int sprintf( char *buffer, const char *format [, argument] ... ); 除了前两个参数类型固定外,后面可以接任意多个参数。而它的精华,显然就在第二个参数: 格式化字符串上。
 
printf 和sprintf 都使用格式化字符串来指定串的格式,在格式串内部使用一些以“%”开头的格式说明符(format specifications)来占据一个位置,在后边的变参列表中提供相应的变量,最终函数就会用相应位置的变量来替代那个说明符,产生一个调用者想要的字符串。
 
在一个Sqlite程序中就用到sprintf函数。

#include "sqlite.h"

static sqlite3 *db = NULL;
static char *errmsg = NULL;
static char *name = NULL;

int main(int argc, char *argv[])
{
    if (argc != 3 ) { //check argv
        printf("filename name dis\n");
        exit(1);
    } else {
        printf("wait...\n");
    } //do next

    int rc,id;
    name = malloc(30);
    id = atoi(argv[1]);
    strcpy(name,argv[2]);

    rc = sqlite3_open(DATAPATH, &db); //open datebase
    if (rc) {
        printf("cant open datebase\n");
    }
    else {
        printf("open datebase success\n");
    }
    char query[500];//用作sprintf()函数输出的字符串
    sprintf(query,"update book set name='%s' where id='d'",name,id); //在""之间的全输入到value中去了
    rc = sqlite3_exec(db,query,0,0,&errmsg);
    if (rc) {
        printf("exec update faild\n");
    } else {
        printf("exec update success\n");
    }
    sqlite3_close(db);//close database
    return 0;
}


阅读(1260) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~