随机
字符串
的函数,在连续调用时会返回相同的
字符串
,发现是以time(NULL)作为
随机
种子,于是做了下改进。
将种子改为当前秒数和微秒的和,这样就可以保证连续请求(us等级)多次不会导致生成相同的字符序列。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/time.h>
int get_random_str(char
生成随机
字符串
(三种方式)
一、org.apache.commons.lang包下有一个RandomStringUtils类,其中有一个randomAlphanumeric(int length)函数,可以
随机
生成一个长度为length的
字符串
。
String filename=RandomStringUtils.randomAlphanumeric(10);
二、可以指定某个位置是a-z、A-Z或是0-9,需要导入的包是import java.util.Random;
//可以指定
字符串
的某个位置
o 2.4 extern 在函数声明中是什么意思?
o 2.5 关键字 auto 到底有什么用途?
o 2.6 我似乎不能成功定义一个链表。我试过 typedef struct { char *item; NODEPTR next; } *NODEPTR; 但是编译器报了错误信息。难道在
C语言
中一个结构不能包含指向自己的指针吗?
o 2.7 怎样建立和理解非常复杂的声明?例如定义一个包含 N 个指向返回指向字符的指针的函数的指针的数组?
o 2.8 函数只定义了一次, 调用了一次, 但编译器提示非法重定义了。
o 2.9 main() 的正确定义是什么? void main() 正确吗?
o 2.10 对于没有初始化的变量的初始值可以作怎样的假定?如果一个全局变量初始值为 ``零", 它可否作为空指针或浮点零?
o 2.11 代码 int f() { char a[] = "Hello, world!";} 不能编译。
o 2.12 这样的初始化有什么问题?char *p = malloc(10); 编译器提示 ``非法初始式" 云云。
o 2.13 以下的初始化有什么区别?char a[] = "string literal"; char *p = "string literal"; 当我向 p[i] 赋值的时候, 我的程序崩溃了。
o 2.14 我总算弄清除函数指针的声明方法了, 但怎样才能初始化呢?
* 3. 结构、联合和枚举
o 3.1 声明 struct x1 { ...}; 和 typedef struct { ...} x2; 有什么不同?
o 3.2 为什么 struct x { ...}; x thestruct; 不对?
o 3.3 一个结构可以包含指向自己的指针吗?
o 3.4 在 C 语言中实现抽象数据类型什么方法最好?
o 3.5 在 C 中是否有模拟继承等面向对象程序设计特性的好方法?
o 3.6 我遇到这样声明结构的代码: struct name { int namelen; char namestr[1];}; 然后又使用一些内存分配技巧使 namestr 数组用起来好像有多个元素。这样合法和可移植吗?
o 3.7 是否有自动比较结构的方法?
o 3.8 如何向接受结构参数的函数传入常数值?
o 3.9 怎样从/向数据文件读/写结构?
o 3.10 我的编译器在结构中留下了空洞, 这导致空间浪费而且无法与外部数据文件进行 "二进制" 读写。能否关掉填充, 或者控制结构域的对齐方式?
o 3.11 为什么 sizeof 返回的值大于结构的期望值, 是不是尾部有填充?
o 3.12 如何确定域在结构中的字节偏移?
o 3.13 怎样在运行时用名字访问结构中的域?
o 3.14 程序运行正确, 但退出时却 ``core dump''了,怎么回事?
o 3.15 可以初始化一个联合吗?
o 3.16 枚举和一组预处理的 #define 有什么不同?
o 3.17 有什么容易的显示枚举值符号的方法?
* 4. 表达式
o 4.1 为什么这样的代码: a[i] = i++; 不能工作?
o 4.2 使用我的编译器,下面的代码 int i=7; printf("%d\n", i++ * i++); 返回 49?不管按什么顺序计算, 难道不该打印出56吗?
o 4.3 对于代码 in
在
C语言
中,可以使用各种算法来对
字符串
进行压缩,例如哈夫曼编码、Lempel-Ziv算法等。这些算法可以将
字符串
中重复出现的内容进行压缩,从而减小
字符串
的大小。
其中,哈夫曼编码是一种无损压缩算法,它可以根据
字符串
中各个字符出现的频率来构建一颗哈夫曼树,将字符转换为对应的二进制编码,并将编码后的二进制串进行压缩。
而Lempel-Ziv算法则是一种通用的压缩算法,它将
字符串
看做是由多个重复的子串组成,通过记录已经出现过的子串来进行压缩。
无论使用哪种算法,压缩后的
字符串
都需要通过解压算法来还原为原来的
字符串
。在
C语言
中,可以使用各种库函数来实现
字符串
的压缩和解压,例如zlib、gzip等。