很久没有搞数据结构了,今天定义了一个单链表结果报错:
1. typedef struct LNode 2. { 3. ElemType data; 4. struct LNode * next; 5. }LinkNode;
错误使用:
1. LinkNode head; 2. LinkNode tmp; 3. 4. head.data=0;head.next=tmp; 5. ------------------------------------------------------------------------- 6. error: cannot convert 'LinkNode' {aka 'LNode'} to 'LNode*' in assignment|
也就是说,用结构体名字去定义声明的变量是一个真正的变量,他在内存中分配有自己的存储空间;而是用指针去形式定义的变量是一个指针,使用的时候给他赋予一个结构体变量的地址。
所以上面直接把一个“结构体的所有变量”附给应该是只含一个“地址的值”的指针变量,当然会报错。
正确使用:
1. LinkNode *head; 2. head=(LinkNode *)malloc(sizeof(LinkNode)); 3. head->data=0;head->next=NULL; 4. 5. LinkNode *tmpnode; 6. tmpnode=(LinkNode *)malloc(sizeof(LinkNode)); 7. 8. head->next=tmpnode;
原文:点操作符和箭头操作符_fulima007的博客-CSDN博客_编程点操作符
首先介绍一下C++中的结构。对于一个结构来说:
1. struct MyStruct 2. { 3. int member_a; 4. };
如果有个变量MyStruct s,那么使用其中的成员元素时可以用
s.member_a = 1;
如果采用指针方法访问,比如 MyStruct * ps,那么同样的访问就必须使用如下形式:
(*ps).member_a = 1;
或者
ps->member_a = 1;
c++中当定义类对象是指针对象时候,就需要用到 “->” 指向类中的成员;当定义一般对象时候时就需要用到 “.” 指向类中的成员…….
例如:
1. class A 2. { 3. public: 4. play(); 5. }
如果定义如下:
A *p则:p->play()使用; 左边是结构指针。
A p 则:p.paly()使用; 左边是结构变量。
总结:
箭头(->):左边必须为指针;
点号(.):左边必须为实体。
补充:
C++语言为包含点操作符和解引用操作符的表达式提供了一个同义词:箭头操作符(->)。点操作符用于获取类类型对象的成员:
item1.same_isbn(item2); // run the same_isbn member of item1
如果有一个指向Sales_item对象的指针(或迭代器),则在使用点操作符前,需对该指针(或迭代器)进行解引用:
1. Sales_item *sp = &item1; 2. (*sp).same_isbn(item2); // run same_isbn on object to which sp points
这里,对sp进行解引用以获得指定的Sales_item对象。然后使用点操作符调用指定对象的same_isbn成员函数。在上述用法中,注意必须用圆括号把解引用括起来,因为解引用的优先级低于点操作符。如果漏掉圆括号,则这段代码的含义就完全不同了:
1. // run the same_isbn member of sp then dereference the result! 2. *sp.same_isbn(item2); // error: sp has no member named same_isbn
这个表达式企图获得sp对象的same_isbn成员。等价于:
*(sp.same_isbn(item2)); // equivalent to *sp.same_isbn(item2);
然而,sp是一个没有成员的指针;这段代码无法通过编译。
因为编程时很容易忘记圆括号,而且这类代码又经常使用,所以C++为在点操作符后使用的解引用操作定义了一个同义词:箭头操作符(->)。假设有一个指向类类型对象的指针(或迭代器),下面的表达式相互等价:
1. (*p).foo; // dereference p to get an object and fetch its member named foo 2. p->foo; // equivalent way to fetch the foo from the object to which p points
具体地,可将same_isbn的调用重写为:
sp->same_isbn(item2); // equivalent to (*sp).same_isbn(item2)
AIEarth是一个由众多领域内专家博主共同打造的学术平台,旨在建设一个拥抱智慧未来的学术殿堂!【平台地址:https://devpress.csdn.net/aiearth】 很高兴认识你!加入我们共同进步!