时间:2021-05-19
关于函数外初始化与函数内初始化之前一直分的不是太清,也不太在意。昨天终于出现了这方面的问题,所以决定好好看下,以下是这次的一些收获,先看测试代码:
复制代码 代码如下:
#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.函数内初始化:bool FillStr(char *&szDst, int nSize);
第一个参数中的&一定不能少,这是因为在函数外部我们只声明了这个指针,具体这个指针指向内存中的哪个地址我们并不知道,所以&是为了说明传递的是这个指针的引用,那么在函数内初始化后这个指针的地址也就是外面指针的地址了。
第二个参数是我们要分配的字符个数。
2.函数外初始化:bool FillStr(char *szDst);
这个函数的参数加不加&都可以,因为传进来的时候已经初始化了,已经有了一个确切的地址,如果不加&的话传进来的就是原来地址的拷贝,如果加&的话就是同一个指针。所以不管怎样它们传进来的都是一样的地址,对其操作都是对同一块内存的操作。
虽然上面两种方法都可以达到相同的效果,但是我认为还是第二种方式好些,这样符合谁分配谁释放的原则。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Java在构造函数中,第一行会先调用父类中构造函数进行初始化。父类初始化完毕后,再对子类的属性进行显示初始化。进行子类构造函数的特定初始化。初始化完毕后,将地址
初始化类,结构和枚举当Swift声明后准备初始化类实例。初始值被初始化为存储属性,并且新的实例的值也被进一步进行初始化。创建初始化函数的关键字是通过init()
一.初始化部分: 1.构造函数:创建page类的一个实例,初始化page类的属性. 2.AddParsedSubObject函数: protected
1.只能在构造函数初始化列表初始化的成员变量的类型?a.const成员变量b.引用类型的成员变量c.static不能在初始化列表中进行初始化d.类成员变
Tensorflow提供了7种不同的初始化函数:tf.constant_initializer(value)#将变量初始化为给定的常量,初始化一切所提供的值。假