欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

函數(shù)外初始化與函數(shù)內(nèi)初始化詳細(xì)解析

 更新時(shí)間:2013年09月30日 09:11:37   作者:  
函數(shù)內(nèi)初始化:bool FillStr(char *&szDst, int nSize);第一個(gè)參數(shù)中的&一定不能少,這是因?yàn)樵诤瘮?shù)外部我們只聲明了這個(gè)指針,具體這個(gè)指針指向內(nèi)存中的哪個(gè)地址我們并不知道,所以&是為了說(shuō)明傳遞的是這個(gè)指針的引用,那么在函數(shù)內(nèi)初始化后這個(gè)指針的地址也就是外面指針的地址了

關(guān)于函數(shù)外初始化與函數(shù)內(nèi)初始化之前一直分的不是太清,也不太在意。昨天終于出現(xiàn)了這方面的問(wèn)題,所以決定好好看下,以下是這次的一些收獲,先看測(cè)試代碼:

復(fù)制代碼 代碼如下:

#include "stdafx.h"
#include <iostream>
using namespace std;
bool FillStr(char *&szDst, int nSize)
{
 bool bRet = false;
 if (nSize > 0)
 {
  szDst = (char*)malloc(sizeof(char) * nSize);
  memset(szDst, 0, sizeof(char) * nSize);
  strcpy(szDst, "hello, world");
  bRet = true;
 }
 return bRet;
}
bool FillStr(char *szDst)
{
 bool bRet = false;
 if (szDst)
 {
  strcpy(szDst, "hello, 5.1");

  bRet = true;
 }
 return bRet;
}
int _tmain(int argc, _TCHAR* argv[])
{
 char* szWord = NULL;
 // 第一種
 //FillStr(szWord, 64);
 // 第二種
 szWord = (char*)malloc(sizeof(char) * 64);
 memset(szWord, 0, sizeof(char) * 64);
 FillStr(szWord);
 printf("%s/n", szWord);
 if (szWord)
 {
  free(szWord);
  szWord = NULL;
 }
 getchar();
 return 0;
}

1.函數(shù)內(nèi)初始化:bool FillStr(char *&szDst, int nSize);

第一個(gè)參數(shù)中的&一定不能少,這是因?yàn)樵诤瘮?shù)外部我們只聲明了這個(gè)指針,具體這個(gè)指針指向內(nèi)存中的哪個(gè)地址我們并不知道,所以&是為了說(shuō)明傳遞的是這個(gè)指針的引用,那么在函數(shù)內(nèi)初始化后這個(gè)指針的地址也就是外面指針的地址了。

第二個(gè)參數(shù)是我們要分配的字符個(gè)數(shù)。

2.函數(shù)外初始化:bool FillStr(char *szDst);

這個(gè)函數(shù)的參數(shù)加不加&都可以,因?yàn)閭鬟M(jìn)來(lái)的時(shí)候已經(jīng)初始化了,已經(jīng)有了一個(gè)確切的地址,如果不加&的話傳進(jìn)來(lái)的就是原來(lái)地址的拷貝,如果加&的話就是同一個(gè)指針。所以不管怎樣它們傳進(jìn)來(lái)的都是一樣的地址,對(duì)其操作都是對(duì)同一塊內(nèi)存的操作。

雖然上面兩種方法都可以達(dá)到相同的效果,但是我認(rèn)為還是第二種方式好些,這樣符合誰(shuí)分配誰(shuí)釋放的原則。

相關(guān)文章

  • C語(yǔ)言中關(guān)于庫(kù)函數(shù) qsort 快排的用法

    C語(yǔ)言中關(guān)于庫(kù)函數(shù) qsort 快排的用法

    快速排序Qsort是所有學(xué)習(xí)算法和數(shù)據(jù)結(jié)構(gòu)最基礎(chǔ)的一個(gè)部分,也是考試題和面試的一個(gè)小重點(diǎn)。本片文章帶你了解Qsort的詳細(xì)用法規(guī)則
    2021-09-09
  • C++對(duì)象的動(dòng)態(tài)建立與釋放詳解

    C++對(duì)象的動(dòng)態(tài)建立與釋放詳解

    我們知道可以用new運(yùn)算符可以動(dòng)態(tài)的分配內(nèi)存,用delete運(yùn)算符可以釋放這些內(nèi)存。當(dāng)我們使用new運(yùn)算符動(dòng)態(tài)的分配一個(gè)內(nèi)存之后,會(huì)自動(dòng)返回一個(gè)該內(nèi)存段的起始地址,也就是指針。
    2013-10-10
  • 詳解C語(yǔ)言中的wait()函數(shù)和waitpid()函數(shù)

    詳解C語(yǔ)言中的wait()函數(shù)和waitpid()函數(shù)

    這篇文章主要介紹了C語(yǔ)言中的wait()函數(shù)和waitpid()函數(shù),注意其在中斷進(jìn)程方面用法的不同,需要的朋友可以參考下
    2015-08-08
  • C語(yǔ)言動(dòng)態(tài)內(nèi)存的分配最全面分析

    C語(yǔ)言動(dòng)態(tài)內(nèi)存的分配最全面分析

    動(dòng)態(tài)內(nèi)存是相對(duì)靜態(tài)內(nèi)存而言的。所謂動(dòng)態(tài)和靜態(tài)就是指內(nèi)存的分配方式。動(dòng)態(tài)內(nèi)存是指在堆上分配的內(nèi)存,而靜態(tài)內(nèi)存是指在棧上分配的內(nèi)存,本文帶你深入探究C語(yǔ)言中動(dòng)態(tài)內(nèi)存的管理
    2022-08-08
  • 利用C語(yǔ)言實(shí)踐OOP,以及new,delete的深入分析

    利用C語(yǔ)言實(shí)踐OOP,以及new,delete的深入分析

    本篇文章是對(duì)用C語(yǔ)言實(shí)踐OOP,new,delete進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C語(yǔ)言字符串替換:字符,字符串,字符數(shù)組詳解

    C語(yǔ)言字符串替換:字符,字符串,字符數(shù)組詳解

    這篇文章主要介紹了C++字符串替換的字符,字符串,字符數(shù)組,需要考慮的情況比較全面,有不錯(cuò)的借鑒價(jià)值,需要的朋友可以參考下
    2021-09-09
  • C語(yǔ)言實(shí)現(xiàn)電影管理系統(tǒng)

    C語(yǔ)言實(shí)現(xiàn)電影管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)電影管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • OpenGL實(shí)現(xiàn)中點(diǎn)劃線法

    OpenGL實(shí)現(xiàn)中點(diǎn)劃線法

    這篇文章主要為大家詳細(xì)介紹了OpenGL實(shí)現(xiàn)中點(diǎn)劃線法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • C++實(shí)現(xiàn)簡(jiǎn)單的通訊錄管理系統(tǒng)

    C++實(shí)現(xiàn)簡(jiǎn)單的通訊錄管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)單的通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • C語(yǔ)言實(shí)現(xiàn)SM4加解密方式

    C語(yǔ)言實(shí)現(xiàn)SM4加解密方式

    這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)SM4加解密方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04

最新評(píng)論