- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所有,在删除该节点之前实现对包含行号“x”的节点的搜索,我遇到了一个问题,其中正向和反向搜索都识别正确的节点,但调用者节点地址的指针报告不同反向搜索优于正向搜索?这仅适用于最后一个节点(最高行号)。如果仅使用前向搜索(pba_fwd_iter_test),则最后一个节点将被正确删除。但是,如果使用反向搜索(pba_rev_iter_test),则“(victim->next)->prev =victim->prev;”设置的地址不正确,它设置“(victim->next)->prev = (victim->next)->prev”。例如,通过反向搜索到达结束节点,然后执行delete_node 结果如下:
49: 7 - (line to delete) This is a line of text that is somewhere around 50 to 80 characters in length
48 - prev: 0x604a80 cur: 0x604b10 next: 0x604ba0
49 - prev: 0x604b10 cur: 0x604ba0 next: 0x603010 <-- delete_node
0 - prev: 0x604ba0 cur: 0x603010 next: 0x6030a0
48 - prev: 0x604a80 cur: 0x604b10 next: 0x603010
49 - prev: 0x604b10 cur: 0x604ba0 next: 0x603010 <-- (node deleted)
0 - prev: 0x603010 cur: 0x603010 next: 0x6030a0
\_______________\______ Error (should be prev: 0x604b10)
@WhosCraig 慷慨地帮助了 delete_node 函数,该函数工作正常,但我无法弄清楚为什么当使用反向搜索结果定位同一节点时,delete_node 无法设置“(victim->next)->prev =victim->上一页;”适本地。作为反向搜索的测试,我只是简单地向开头添加一个节点,然后向前一个节点返回到有问题的节点,然后 delete_node 工作正常。 (只需附加:list = &(*list)->prev; list = &(*list)->next;。因此,问题与通过反向搜索到达结束节点时的指针状态有关而不是正向搜索——这就是我需要帮助弄清楚的。这是正向和反向搜索以及快速 ->prev ->next 之后的指针地址的输出:
=========== pba_fwd_iter_test() ===========
passing list = &(*list)->next to tstpptr (0x605b28)
tstpptr(): list : 0x605b28
tstpptr(): &list : 0x7ffff14633a8
tstpptr(): *list : 0x605ba0
tstpptr(): &(*list) : 0x605b28 <- caller's address reported
tstpptr(): &(**list): 0x605ba0 with forward search
tstpptr(): &(*list)->next : 0x605bb8
=========== pba_rev_iter_test() ===========
passing list = &(*list)->next to tstpptr (0x604020)
tstpptr(): list : 0x604020
tstpptr(): &list : 0x7ffff14633a8
tstpptr(): *list : 0x605ba0
tstpptr(): &(*list) : 0x604020 <- caller's address reported
tstpptr(): &(**list): 0x605ba0 with reverse search
tstpptr(): &(*list)->next : 0x605bb8
passing list = &(*list)->next to tstpptr (0x605b28)
tstpptr(): list : 0x605b28
tstpptr(): &list : 0x7ffff14633a8
tstpptr(): *list : 0x605ba0
tstpptr(): &(*list) : 0x605b28 <- caller's address reported after
tstpptr(): &(**list): 0x605ba0 &(*list)->prev; &(*list)->next
tstpptr(): &(*list)->next : 0x605bb8
以下是相关的代码片段,开头带有完整源代码的链接。感谢您提供的任何帮助:
/*
full source: http://www.3111skyline.com/dl/dev/prg/src/ll-double-cir-1.c.txt
*/
struct record
{
char *line;
int lineno;
int linetype;
struct record *prev;
struct record *next;
};
typedef struct record rec;
void // traverse in fwd direction to find hightest line no.
pba_fwd_iter_test (rec **list, int num);
void // traverse in rev direction to find hightest line no.
pba_rev_iter_test (rec **list, int num);
void // dump the pointers for examination
tstpptr (rec **list);
int main (int argc, char *argv[]) {
// <snip> fill struct with 50 records for testing (lineno '0' based 0-49)
pba_fwd_iter_test (&textfile, 49);
pba_rev_iter_test (&textfile, 49);
return 0;
}
void
pba_fwd_iter_test (rec **list, int num) {
printf ("=========== %s() ===========\n",__func__);
int linemax = getmaxline (*list);
int iterno = 0;
while (((*list)->lineno != num) && (iterno <= linemax)) {
iterno++;
list = &(*list)->next;
}
printf ("passing list = &(*list)->next to tstpptr (%p)\n", list);
tstpptr (list);
}
void
pba_rev_iter_test (rec **list, int num) {
printf ("=========== %s() ===========\n",__func__);
int linemax = getmaxline (*list);
int iterno = 0;
while (((*list)->lineno != num) && (iterno <= linemax)) {
iterno++;
list = &(*list)->prev;
}
printf ("passing list = &(*list)->next to tstpptr (%p)\n", list);
tstpptr (list);
// increment prev then next and check ptr values again
list = &(*list)->prev;
list = &(*list)->next;
printf ("passing list = &(*list)->next to tstpptr (%p)\n", list);
tstpptr (list);
}
void
tstpptr (rec **list) {
fprintf (stdout, "%s(): list : %p\n", __func__, list);
fprintf (stdout, "%s(): &list : %p\n", __func__, &list);
fprintf (stdout, "%s(): *list : %p\n", __func__, *list);
fprintf (stdout, "%s(): &(*list) : %p\n", __func__, &(*list));
fprintf (stdout, "%s(): &(**list) : %p\n\n", __func__, &(**list));
fprintf (stdout, "%s(): &(*list)->next : %p\n\n", __func__, &(*list)->next);
}
最佳答案
我想我看到了问题所在 - 我认为不存在这个问题。重要的值是*list
,它在所有情况下都是相同的。我认为打印列表和 &list 等只会使问题变得模糊。
在前向迭代器中,list
指向项目 #48 的 next
变量的位置。
在向后迭代器中,list
指向项目 #0 的 prev
变量的位置。
在这两种情况下,*list 都指向正确的项目 #49。
如果这两个函数只采用 rec *
而不是 rec **
,那么它们会更简单,那么采用list
变量不是您想要的。
关于C循环双链表: traverses fwd/rev for end node gives different pointer address,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22623189/
编译器知道AbstractDemo是一个抽象类,抽象类不能被实例化。 但是当我调用 newInstance() 方法时,为什么它没有给出编译时错误? import java.lang.reflect.
假设我有如下数据类型: data Cell = Cell (Maybe Player) data Board = Board [[Cell]] 现在我想生成一个这样的递归函数: genBoard
当谈到使用 OpenMP 和 TBB 进行共享内存编程时,我是一个初学者。 我正在实现 QuickHull 算法 ( http://en.wikipedia.org/wiki/QuickHull )
我想创建一个随机列表与列表中元素的不同组合。出现在最终列表中的每个元素的计数应该相同。。例如。在这里,我期望所有元素的计数都是10,因为我给了相同的权重。但这并不总是一样的。如何修改代码以使所有元素的
我想创建一个随机列表与列表中元素的不同组合。出现在最终列表中的每个元素的计数应该相同。。例如。在这里,我期望所有元素的计数都是10,因为我给了相同的权重。但这并不总是一样的。如何修改代码以使所有元素的
以下将显示在 Firebug 或 jsconsole.com 中或在其他 Javascript 交互式控制台中: >>> foo = { a : 1, b : 2.2 } Object { a=1,
在 Azure DevOps 管道中的一项任务中,我尝试停止 IIS 服务器。这可以通过在命令提示符中调用命令net stop WAS来实现。手动执行此操作,它会要求确认 手动方式,我只需按 Y EN
在 Azure DevOps 管道中的一项任务中,我尝试停止 IIS 服务器。这可以通过在命令提示符中调用命令net stop WAS来实现。手动执行此操作,它会要求确认 手动方式,我只需按 Y EN
在 R 编码中出现以下错误。 在我的 Brand_X.xlsx 数据集中,我尝试使用 KNN 插补法计算的 NA 值很少,但我得到的结果低于错误。这里有什么问题吗?谢谢! > library(read
在 Android Studio 中,我希望我的每个应用变体都有自己的图标。 我尝试了各种方法,包括此处建议的方法 How to provide different Android app icons
JSFiddle 示例代码:http://jsfiddle.net/SUMPq/8/ 我在容器上有一些文本,代码位于 HTML 的顶部,靠近正文: Heading TAG SOME TEXTSOM
所以我正在实现这个简单的剃须刀支付集成。但它给我一个“没有找到合适的付款方式”的错误。我之前尝试过选择付款选项表,但也没有用。 val razorpay = RazorpayClient("my
Closed. This question needs to be more focused。它当前不接受答案。 想要改善这个问题吗?更新问题,使它仅关注editing this post的一个问题。
我在玩 elm-css . 大多数事情都按我的预期工作。 但是我无法为 Css.opacity 提供正确的值功能。 这是我尝试过的: Css.opacity 0.5 这给出了错误: Function
请参阅以下代码: UIImage *image; NSString *str = [[[Data getInstance]arrPic]objectAtIndex:rowIndex]; NSLog(s
这个问题已经有答案了: "Notice: Undefined variable", "Notice: Undefined index", "Warning: Undefined array key",
我正在测试一个用于修改文件的工具,在此过程中一个相当重要的功能是告诉文件大小,尤其是当文件仍然打开时。 $file = tempnam('/tmp', 'test_'); file_put_conte
我是Java/Maven新手,我正在尝试构建一个maven Spring Boot项目,它很早就可以工作并且也成功创建了jar包。但它突然停止工作并开始出现 Maven 编译错误。 我知道它与 pom
我正在尝试让我的 pom.xml 在我的 JAXB 对象上生成 hashCode() 和 equals method()。 4.0.0 0.0.1-SNAPSHOT jar
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 8 年前。 Improv
我是一名优秀的程序员,十分优秀!