Notes
This function is in beta test. Please help improve it in the issues
here.
================================================================= ==121438==ERROR: AddressSanitizer: heap-buffer-overflow on address 0x602000000010 at pc 0x00000051c280 bp 0x7ffc97e32b50 sp 0x7ffc97e32b48 WRITE of size 8 at 0x602000000010 thread T0 #0 0x51c27f (/out/package/dlist_mem+0x51c27f) #1 0x51f3cf (/out/package/dlist_mem+0x51f3cf) #2 0x7f05ffd0bc86 (/lib/x86_64-linux-gnu/libc.so.6+0x21c86) #3 0x41da19 (/out/package/dlist_mem+0x41da19) 0x602000000014 is located 0 bytes to the right of 4-byte region [0x602000000010,0x602000000014) allocated by thread T0 here: #0 0x515e80 (/out/package/dlist_mem+0x515e80) #1 0x51ba77 (/out/package/dlist_mem+0x51ba77) #2 0x7f05ffd0bc86 (/lib/x86_64-linux-gnu/libc.so.6+0x21c86) SUMMARY: AddressSanitizer: heap-buffer-overflow (/out/package/dlist_mem+0x51c27f) Shadow bytes around the buggy address: 0x0c047fff7fb0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 0x0c047fff7fc0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 0x0c047
Hints
Your answer may be identical to the JOJ answer in the first several lines.
However, the main problem you meet now is Runtime Error. And the exit code of your program is 1, which should be 0.
Please double check your code to solve this problem and try again.
Your Answer
JOJ Answer
Test success.