C++ 在我的模板类示例中,即使我没有定义add方法,它也是addstack";分段故障(堆芯倾倒)“;错误

C++ 在我的模板类示例中,即使我没有定义add方法,它也是addstack";分段故障(堆芯倾倒)“;错误,c++,template-classes,C++,Template Classes,!!注意:我在回答之后多次编辑了问题。但下面的问题是第一个问题,第一个答案是一个有用的答案。请不要被一些评论弄糊涂。它们是在我多次更改问题后编写的 我有一个商店模板类和Cookie类。商店是一张保存着饼干的清单,名为cookieShop。Shop cotr可以将一个cookie作为其参数,并且可以通过Shop template类的Add方法添加更多cookie 我正在制作两个饼干。一个是通过车间cotr添加的,第二个是通过添加方法添加的。即使我不在add方法中编写代码,第二个cookie也会添

!!注意:我在回答之后多次编辑了问题。但下面的问题是第一个问题,第一个答案是一个有用的答案。请不要被一些评论弄糊涂。它们是在我多次更改问题后编写的


我有一个商店模板类和Cookie类。商店是一张保存着饼干的清单,名为cookieShop。Shop cotr可以将一个cookie作为其参数,并且可以通过Shop template类的Add方法添加更多cookie

我正在制作两个饼干。一个是通过车间cotr添加的,第二个是通过添加方法添加的。即使我不在add方法中编写代码,第二个cookie也会添加到商店列表中。我试图理解它为什么会这样做,但无法理解

这是我的密码:

//商店

#ifndef SHOP_T
#define SHOP_T
#include <string>
using namespace std;

template<class type>
class Shop;

template<typename type>
ostream& operator<<(ostream& out, const Shop<type>& S){
    for(int i = 0; i < S.size; i++)
        out << i + 1 << ".\t" << S.list[i] << endl;
}

template<class type>
class Shop{
    type *list;
    string name;
    int size;
public:
    Shop() { list = 0; size = 0; }
    Shop(type t);
    ~Shop(){ delete[] list; }
    void Add(type A);
    friend ostream& operator<< <>(ostream& out, const Shop<type>& S);
};

template<class type>
Shop<type>::Shop(type t) : size(0){
    list = new type;
    list = &t;
    size++;
}

template<class type>
void Shop<type>::Add(type A){
//  type *temp = new type[size+1];
//  for(int i = 0; i < size; i++)
//      temp[i] = list[i];
//  delete[] list;
//  temp[size] = A;
//  list = temp;
    size++;
}

#endif
\ifndef车间
#定义车间
#包括
使用名称空间std;
模板
高级商店;
模板
ostream&运算符此处:

模板
车间:车间(t型):尺寸(0){
列表=新类型;
列表=&t;
大小++;
}
变量
t
是此函数的局部变量。将
list
设置为指向该变量的指针。当函数终止时,变量将超出范围,商店将保留一个悬空指针,您将得到未定义的行为。

此处:

template<class type>
Shop<type>::Shop(type t) : size(0){
  list = new type;
  list = &t;
  size++;
}
模板
车间:车间(t型):尺寸(0){
列表=新类型;
列表=&t;
大小++;
}


变量
t
是此函数的局部变量。将
list
设置为指向该变量的指针。当函数终止时,变量将超出作用域,商店将保留一个悬空指针,您将获得未定义的行为。

您忘记注释掉
size++
中添加
@NathanOliver。因为我想打印列表[1]。我认为问题不在于此。是吗?谁教你原始数组是一个有用的容器,那就大错特错了。你最好使用
std::vector
这是一个家庭作业。我不得不这样做。截止日期已经结束。不幸的是,我如上所述发送了家庭作业。但是现在我想学习。我为你的学习愿望喝彩,但是1)请不要以完全改变它们的方式编辑你的问题,2)当你编写代码时,最好从一个小而简单、工作完美的东西开始,当你在这里发布代码时,最好将其减少到最小,产生错误的最简单代码。您忘记注释掉
size++
中添加
@NathanOliver。因为我想打印列表[1]。我认为问题不在于此。是吗?谁教你原始数组是一个有用的容器,那就大错特错了。你最好使用
std::vector
这是一个家庭作业。我不得不这样做。截止日期已经结束。不幸的是,我如上所述发送了家庭作业。但是现在我想学习。我为你的学习愿望喝彩,但是1)请不要以完全改变它们的方式编辑你的问题,2)当你编写代码时,最好从一些小而简单、工作完美的东西开始,当你在这里发布代码时,最好将其减少到产生错误的最小、最简单的代码。哦。我在这里写了很糟糕的代码。我会尽力改正的。谢谢。
list=new type
list=&t
delete[]list
@Caleth不匹配也会导致UB。为什么在我更改您提到的代码后,它仍然会给出分段错误?我对修改后的代码也是错的吗?@Murat:现在你调用了
Add
函数,但大部分还是被注释掉了;它没有添加Cookie,它只是增加
大小
。然后,当您尝试打印第二个Cookie时,您读取的内容超过了数组的末尾(它不是真正的数组,
Cookie
不是
Cookie[1]
),并且再次获得未定义的行为。@Beta:我已经通过注释部分尝试了代码:
cookieShop.Add(cookie2)。对不起,我忘了在这儿换了。但是我得到了和上面一样的结果。我在这里写了很糟糕的代码。我会尽力改正的。谢谢。
list=new type
list=&t
delete[]list
@Caleth不匹配也会导致UB。为什么在我更改您提到的代码后,它仍然会给出分段错误?我对修改后的代码也是错的吗?@Murat:现在你调用了
Add
函数,但大部分还是被注释掉了;它没有添加Cookie,它只是增加
大小
。然后,当您尝试打印第二个Cookie时,您读取的内容超过了数组的末尾(它不是真正的数组,
Cookie
不是
Cookie[1]
),并且再次获得未定义的行为。@Beta:我已经通过注释部分尝试了代码:
cookieShop.Add(cookie2)。对不起,我忘了在这儿换了。但是我得到了与上面相同的结果。
#include "Cookie.h"
#include <iostream>
#include <string>
using namespace std;

Cookie::Cookie() {}
Cookie::Cookie(string n, int pi, float pr){
      name = n;
      piece = pi;
      price = pr;
}

ostream& operator<<(ostream& o, const Cookie& C){
    o << C.name << "\t" << C.piece << "\t" << C.price;
}
#include <iostream>
#include <string>
#include "Shop.h"
#include "Cookie.h"

using namespace std;
int main(){
    Cookie cookie1("Chocolate Cookie", 50, 180);
    Cookie cookie2("Cake Mix Cookie", 60, 200);

    Shop<Cookie> cookieShop(cookie1);
    cookieShop.Add(cookie2);

    cout << cookieShop <<endl;


    return 0;
}
template<class type>
Shop<type>::Shop(type t) : size(0){
  list = new type;
  list = &t;
  size++;
}