C核心技术手册(三十一)

4.2.3 隐式指针转换

  编译器隐式地转换确定的指针类型,分配、条件表达式使用操作符==!=,函数调用使用三种隐式的指针转换,如下节所描述,三种隐式指针转换:

l  一个指针对象类型可以隐式地转换为void指针,反之亦然;

l  一个给定类型的指针可以隐式地转换为一个该类型更合格的版本;

l  一个null指针常可以隐式地转换为任意指针类型。

4.2.3.1 指针转换为void

  Void指针为具有void *类型的指针,通常称为多用途指针,可以表示任意对象的地址,而不关心它的类型,例如,malloc()函数返回一个void指针,在你使用内存块前,void指针必须转换为指向一个对象的指针。

  Example 4-1示范了void指针的多个用途,程序使用标准函数qsort() 对数组进行排序,此函数定义在头文件stlib.h中,其原型如下:

      void qsort( void *array, size_t n, size_t element_size,
                int (*compare)(const void *, const void *) );

qsort()以升序排列数组元素,以array地址开始,使用快速排序算法,假定函数具有n的元素,其大小为element_size

  4个参数compareqsort()调用的用做排序的函数指针,用来比较的两个元素的地址通过此函数指针的参数传入,通常,比较函数由程序定义,其返回值必须大于0,或小于0,或等于0,以表示第一个元素大于、或小于、或等于第二个元素。

Example 4-1. A comparison function for qsort( )

#include <stdlib.h>
#define ARR_LEN 20
 
/*
 * A function to compare any two float elements,
 * for use as a call-back function by qsort( ).
 * Arguments are passed by pointer.
 *
 * Returns: -1 if the first is less than the second;
 *           0 if the elements are equal;
 *           1 if the first is greater than the second.
 */
int  floatcmp( const void* p1, const void* p2 )
{
  float x = *(float *)p1,
        y = *(float *)p2;
 
  return (x < y) ? -1 : ((x == y) ? 0 : 1);
}
 
/*
 * The main( ) function sorts an array of float.
 */
int main( )
{
  /* Allocate space for the array dynamically:  */
  float *pNumbers = malloc( ARR_LEN * sizeof(float) );
 
  /* ... Handle errors, initialize array elements ... */
 
  /* Sort the array: */
  qsort( pNumbers, ARR_LEN, sizeof(float), floatcmp );
 
  /* ... Work with the sorted array ... */
 
   return 0;
}

在上面的例子中,malloc()函数返回一个void *,接着,在qsort()中对pNumbers赋值时被隐式地转换为float*,第一个参数隐式地由float*转换为void*,函数名floatcmp隐式地解释为函数指针,最终,当floatcmp()qsort()调用时,它接收void*类型的参数,在初始化float变量前必须显式地转换为float*类型。

你可能感兴趣的:(c,算法,function,less,float,编译器)