我确定这是一个大脑放屁,但我错过了一些东西,谷歌搜索似乎没有提出任何东西。
struct item
{
int a;
int b;
int c;
};
typedef item *itemcatalog;
所以' itemcatalog'只是一个项目阵列。
const item items[] = {{1,2,3},{4,5,6}};
const item *collection = items; // OK
const itemcatalog catalog = items; // "item const *" is incompatible with "itemcatalog"
这个想法是" itemcatalog"更具描述性,并显示预期的项目数组,而不仅仅是指向单个项目的指针。
编辑:修复拼写错误。
答案 0 :(得分:5)
在失败的行上,您忘记为该对象命名。
const itemcatalog collection2 = items;
当我们这样做时,我们仍会收到错误:
foo.cc:14:19: error: cannot initialize a variable of type 'const itemcatalog' (aka 'item *const') with an lvalue of type 'const item [2]'
const itemcatalog catalog = items;
^ ~~~~~
1 error generated.
要解决这个问题,我们需要意识到在这种情况下我们实际上需要两个typedef:
struct item
{
int a;
int b;
int c;
};
typedef item *itemcatalog;
typedef const item *constitemcatalog;
const item items[] = {{1,2,3},{4,5,6}};
const item *collection = items;
const constitemcatalog collection2 = items;
item mutable_items[] = {{1,2,3},{4,5,6}};
const item *collection3 = mutable_items;
const itemcatalog collection4 = mutable_items;
在各种集合对象上,我们正在应用的const
告诉我们是否可以移动指针。 constitemcatalog
vs itemcatalog
告诉我们是否可以修改指针指向的数据。