删除数组时出现strncpy字符字符串问题



我不知道,这个错误有问题。但是,我认为我应该在删除[]cpp之前删除uName[]。我该怎么办?

#define _CRT_SECURE_NO_WARNINGS 1
#include <iostream>
#include <string.h>
using namespace std;
class cppUr
{
public:
    void writeName(char nm[]);
    char * readName();
private:
    char uName[80];
};
void cppUr::writeName(char nm[])
{
    strncpy(uName, nm, 79);
}
char * cppUr::readName()
{
    return uName;
}

主要是:

int main()
{
    char name0[100];
    char name1[100];
    char name2[100];
    char name3[100];
    cppUr *cpp = new cppUr[3];
    cout << "Input first name: "<<endl;
    cin.getline(name0, 100);
    cpp[0].writeName(name0);
    cout << "Input second name: " << endl;
    cin.getline(name1, 100);
    cpp[1].writeName(name1);
    cout << "Input third name: " << endl;
    cin.getline(name2, 100);
    cpp[2].writeName(name2);
    cout << "Input fourth name: " << endl;
    cin.getline(name3, 100);
    cpp[3].writeName(name3);
    for (int i = 0; i < 4; i++)
    {
        cpp[i].readName();
        cout << "The "<<i<<" name " << cpp[i].readName() << endl;
    }
    delete[] cpp;
    system("PAUSE");
    return 0;
}

错误为:

HEAP CORRUPTION DETECTED:在0x0059E1E0处的正常块(#148(之后。CRT检测到应用程序在堆缓冲区结束后写入内存

错误非常简单。

您使用3元素从ccpUr创建数组,但在使用4这些元素之后。

当然,c++是基于null的索引语言,但这意味着最后一种语言不可用。这就是为什么在for循环条件中,必须在类似的数组分配中使用相同的数字,即3

想一想,当[3]对4个元素足够时,[2]对3个元素足够,[1]对2个元素够,[0]对1个元素够?你感觉到了吗?零大小的数组是不够的。

关于

最新更新