reference binding to misaligned address 0x00000001ddb1 for type 'const int',
https://leetcode.com/problems...
题的链接
以下是代码
ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
int i = 1, v1 = 0, v2 = 0;
ListNode begin(0);
begin.next = NULL;
ListNode *Tag = &begin;
bool rouding = false;
while (true)
{
if (l1 == NULL&&l2==NULL&&rouding!=true)
{
break;
}
int value = (l1 == NULL ? 0 : l1->val) + (l2 == NULL ? 0 : l2->val);
if (rouding)
{
value += 1;
rouding = false;
}
if (value >= 10)
{
rouding = true;
value = value % 10;
}
//new部分
ListNode *v;
v = new ListNode(value);
//malloc部分 (报错)
ListNode *v = NULL;
v = (ListNode *)malloc(sizeof(v));
v->val = value;
v->next = NULL; //此操作也是在线编译报错错误如下
// store to address 0x000000a7de78 with insufficient space for an object of type 'struct ListNode *'
Tag->next = v;
Tag = Tag->next;
l1 = l1==NULL?NULL:l1->next;
l2 = l2==NULL?NULL:l2->next;
}
return begin.next;
}
sizeof(v)를 sizeof(*v)로 바꾸세요.
v는 객체가 아니라 포인터입니다. sizeof(v)는 현재 플랫폼에서 다음 포인터의 크기를 반환합니다(32비트는 4, 64입니다). -bit 시스템은 8 ),
ListNode의 크기에는 포인터와 int가 포함되며, 이는 sizeof(v)에서 반환된 값보다 커야 합니다.
그래서 런타임에 메모리 액세스 오류가 발생할 가능성이 매우 높습니다.