C語言中文網 目錄
首頁 > 編程筆記 > C語言筆記 閱讀:8,307

void_C語言void關鍵字詳解

void類型修飾符(type specifier)表示“沒有值可以獲得”。因此,不可以采用這個類型聲明變量或常量。void 類型可以用于下面各小節所描述的目的。

void用于函數聲明

沒有返回值的函數,其類型為 void。例如,標準庫函數 perror() 被聲明為以下原型:
void perror( const char * );
下面是另一個函數原型的聲明,參數列表中的關鍵字 void 表示該函數沒有參數:
FILE *tmpfile( void );
如果嘗試進行函數調用,例如采用 tmpfile("name.tmp"),則編譯器會報錯。如果該函數聲明時參數列表中未采用 void,則C編譯器就無法獲得關于該函數參數的信息,因此,無法判斷 tmpfile("name.tmp") 的調用是否正確。

void類型表達式

void 類型表達式指的是沒有值的表達式。例如,調用一個沒有返回值的函數,就是一種 void 類型表達式:
char filename[] = "memo.txt";
if ( fopen( filename, "r") == NULL )
    perror( filename );  // void表達式
類型轉換(cast)運算(void)表達式顯式地將表達式的返回值丟棄,例如,如下代碼丟棄了函數返回值:
(void)printf("I don't need this function's return value!\n");

指向void的指針

一個 void* 類型的指針代表了對象的地址,但沒有該對象的類型信息。這種“無數據類型”的指針主要用于聲明函數,讓函數可使用各種類型的指針參數,或者返回一個“多用途”的指針。例如,標準內存管理函數:
void *malloc( size_t size );
void *realloc( void *ptr, size_t size );
void free( void *ptr );
如下例所示,可將一個 void 指針值賦值給另一個對象指針類型,反之亦可,這都不需要進行顯式的類型轉換。

:演示void類型的用法:
#include <stdio.h>
#include <time.h>
#include <stdlib.h> // 提供以下函數的原型
                    // void srand( unsigned int seed );
                    // int rand( void );
                    // void *malloc( size_t size );
                    // void free( void *ptr );
                    // void exit( int status };
enum { ARR_LEN = 100 };

int main ()
{
    int i, *pNumbers = malloc(ARR_LEN * sizeof(int));  //獲得相同的存儲空間
    if( pNumbers == NULL )
    {
        fprintf(stderr,"Insufficient memory.\n");
        exit(1);
    }
    srand( (unsigned)time(NULL );  // 初始化隨機數產生器

    for ( i=0; i < ARR_LEN; ++i )
        pNumbers[i] = rand() % 10000;  // 存儲一些隨機數

    printf("\n%d random numbers between 0 and 0000:\n", ARR_LEN);
    for ( i=0; i< ARR_LEN; ++i )                // 循環輸出
    {
        printf("%6d",pNumbers[i]);  // 每次循環輸出一個數字
        if ( i % 10 == 9) putchar( '\n');  // 每10個數字換一行
    }
    free( pNumbers );  // 釋放存儲空間
    return 0;
}

精美而實用的網站,提供C語言C++STLLinuxShellJavaGo語言等教程,以及socketGCCviSwing設計模式JSP等專題。

Copyright ?2011-2018 biancheng.net, 陜ICP備15000209號

底部Logo