Linux平台的ctime()函数

最近在从mysql数据库取数据,显示到界面上时,发现第三列明显比前面2列显示要靠上(不在同一水平线上)。Linux平台的ctime()函数_第1张图片

想到应该是在向数据库插入数据时使用的是ctime()函数,记得这个函数返回的const char *末尾有一个\n(换行符)。man手册给出ctime()说明:

 It  converts  the calendar time t into a null-terminated string of the form

       "Wed Jun 30 21:49:08 1993\n"

要把原来插入数据库的代码进行以下修改(大概多加3行)

/* 修改前 */
time(&timer);
bzero(sql, 100);
sprintf( sql, "insert into online_dev(ip,port,time) values('%s',%d,'%s')", inet_ntoa(cli_addr.sin_addr), ntohs(cli_addr.sin_port), ctime(&timer));

/* 修改后 */
time(&timer);
char ch[26]={0};  //ctime()返回字符串长度是25
strcpy(ch, ctime(&timer));
ch[25]=0;         //把换行符(\n)换成0
bzero(sql, 100);
sprintf( sql, "insert into online_dev(ip,port,time) values('%s',%d,'%s')", inet_ntoa(cli_addr.sin_addr), ntohs(cli_addr.sin_port), ch);
修改后截图:

Linux平台的ctime()函数_第2张图片

说道ctime(),以前还闹过笑话,先看正常代码

#include 
#include 
int main()
{
	time_t timer;
	time(&timer);
	printf( "%s",ctime(&timer) );
	return 0;
}
当时以为自己聪明谢了下面一段代码:

#include 
#include 
int main()
{
	//time_t timer;
	//time(&timer);
	printf( "%s",ctime(&time(NULL)) );
	return 0;
}
本来以为可以省掉一个中间变量timer,而且显得高大上。编译时给出错误: 单目‘&’的操作数必须是左值,这段代码想直接对time()的返回值取地址,这是绝对不正确的,因为函数返回值是匿名变量,只能当右值,不可以做左值。如果真要想使用这个匿名或者说是临时变量,可以使用c++的常引用来接这个返回值。代码如下:

#include 
#include 
int main()
{
	const time_t & timer=time(NULL); //使用常引用timer引用time()返回的临时变量,延长了该临时变量的生存周期
	printf( "%s",ctime(&timer) );    //
	return 0;
}
记得编译时用g++,不要用gcc了。



你可能感兴趣的:(Linux,C++,MySQL)