用sprintf就可以了:
sprintf(string, "%d", number);同理,也可以同sprintf把long型或浮点型转换成字符串(使用%ld或%f),也就是说,可以把sprintf看成是atol或者atof的
反函数。
第一个问题,mktime接受没有规范话的日期,所以可以用一个日期的struct tm结构,直接在tm_mday域上进行加减,然后
调用mktime进行规范化,同时也返回了time_t值。但是主要不要超过tm中成员域的最大表示范围。
实践如下:
在2014/5/16日上加20天。
#include <stdio.h> #include <time.h> int main(void) { struct tm tm1; tm1.tm_year = 2014 - 1900; tm1.tm_mon = 5 - 1; tm1.tm_mday = 16; tm1.tm_hour = tm1.tm_min = tm1.tm_sec = 0; tm1.tm_isdst = 0; tm1.tm_mday += 20; if (mktime(&tm1) == -1) { } else { printf("%d/%d/%d\n",tm1.tm_year+1900, tm1.tm_mon+1, tm1.tm_mday); } return 0; }运行结果:
2014/6/5
第二个问题,可以使用mktime的返回值time_t,然后调用difftime获取他们的差值。
实践如下:
获取2014/5/16 到2014/6/5值
#include <stdio.h> #include <time.h> int main(void) { struct tm tm1,tm2; tm1.tm_year = 2014 - 1900; tm1.tm_mon = 5 - 1; tm1.tm_mday = 16; tm1.tm_hour = tm1.tm_min = tm1.tm_sec = 0; tm1.tm_isdst = 0; tm2.tm_year = 2014 - 1900; tm2.tm_mon = 6 - 1; tm2.tm_mday = 5; tm2.tm_hour = tm1.tm_min = tm1.tm_sec = 0; tm2.tm_isdst = 0; time_t t1,t2; t1 = mktime(&tm1); t2 = mktime(&tm2); long d = difftime(t2,t1)/86400; printf("%ld\n",d); return 0; }运行结果:
20
使用rand函数。从srand (seed)中指定的seed开始,返回一个[0, RAND_MAX]间的随机整数。RAND_MAX被定义在stdlib.h
中:
/* The largest number rand will return (same as INT_MAX). */
#define RAND_MAX 2147483647
#include <stdlib.h> #include <stdio.h> int main(void) { printf("%d\n", rand()); return 0; }但是每次运行的结果都是相同的:
1804289383
为了避免每次产生的随机数序列相同,通常用srand((unsigned)time(0))或者srand((unsigned)time(NULL))来产生种子:
rand()在每次被调用的时候,它会查看:
1)如果用户在此之前调用过srand(seed),给seed指定了一个值,那么它会自动调用srand(seed)一次来初始化它的起始值。
2) 如果用户在此之前没有调用过srand(seed),它会自动调用srand(1)。
所以上面的程序每次执行结果都是相同的。下面添加srand调用:
#include <stdlib.h> #include <stdio.h> int main(void) { srand((unsigned)time(NULL)); printf("%d\n", rand()); return 0; }执行结果:
1307772800
2067487507
但是如果在同一时间运行(精确到秒),则还是会出现相同的现象。