int CompStrLen(const void* a, const void* b)
{
if(strlen((char**)a)==strlen((char**)b))
return strcmp((char**)a, (char*)b);
return strlen((char**)a) - strlen(*(char**)b);
}
不明白为什么强制转换用的是char** 而不是char*,char**代表什么含义?请教了。
一点错误都没有.这是C/C++使用指针的最高境界.(我经常用类似这个例子向自以为很懂指针的人说明到底什么才叫指针!)
其实是要把a 从const void类型转换成char类型.而直接做这样的转换是编译器所不能容忍的.你想想,把常量转成非常量编译器它能受得了吗?
并不是所有的数据类型都可以相互转换的,但是所有的指针类型都可以相互转换.
于是,我们把a的地址(注意,指针本身也是变量,也有自己的地址)取出来,假设叫p吧, 现在p是一个指向a的指针.其类型是void**.由于指针类型间的转换是编译器允许的(比如可以把char转成int),我们把它转成char**( (void*)* -> (char*)* ),也就是告诉编译器,现在p不是指向void了,而是指向char了.最后,我们把p解引用,得到了一个char*.
整个过程可以概括为:取地址,指针类型转换,解引用.
这种方法可以绕过编译器的检查,转换任意类型的数据.
除非写非常底层的库函数,否则不要这样使用.绕过编译器的检查会带来很多安全问题!这也是java不能直接用指针的根本原因.
在本例中,strlen()要求使用char类型的参数,直接将const void传给它编译器必然报错,不得已才用此方法的.