如何解决在成员函数中指向字符数组会不会有问题?
int setString(char *pcString)
{
if( NULL == pcString )
{
pcString = "";
}
if( NULL == m_pcData )
{
m_pcData = new char[m_nBufferLength];
memset(m_pcData,'\0',m_nBufferLength);
}
int nCurrentBuffer = 0;
int nLength = 0;
int nInputStringLength = 0;
nLength = strlen(m_pcData) + knNULL_CHaraCTER_SPACE;
nCurrentBuffer = (m_nBufferLength > nLength) ? m_nBufferLength : nLength ;
nInputStringLength = strlen(pcString) + knNULL_CHaraCTER_SPACE;
if( nCurrentBuffer < nInputStringLength )
{
delete[] m_pcData;
m_pcData = new char[nInputStringLength];
}
strcpy(m_pcData,pcString);
return nInputStringLength;
}
line5 pcString = ""
->可能会出现问题,取决于以后编写代码的方式?
有人指出,这可能是演讲中的问题。
他说
pcString = new char;
pcString[0] = '\0';
是更好的代码。
但是我不明白为什么? 有人可以给我一些解释吗?
pcString = "";
strcpy(pcString,"C++ Problem");
这是其中一种吗?
解决方法
pcString被声明为指向字符的指针,因此隐式假定可以更改这些字符。文字“”是一串常量字符,因此无法更改。出于向后兼容性的原因,C ++允许您进行分配:
pcString = "";
,但以下代码无法编译:
const char* str0 = "";
pcString = str0;
因此,您可以在const
之前添加char* pcString
,此功能就可以了:
int setString(const char *pcString)
{
//....
}
如果pcString字符串应保持可更改,则赋值:
pcString = "";
以下代码可能有问题:
*pcString = '\0'; // undefined behavior (1)
或
delete[] pcString; // undefined behavior (2)
(1)-尝试修改常量字符串 (2)-尝试释放未分配的内存
注意。如果您进行更正:
pcString = new char;
pcString[0] = '\0';
然后您需要提供释放的已分配内存。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。