- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我制作了一个链表和一个返回迭代器的函数。将迭代器分配给另一个指针并释放指针时,它什么都不做,因为它不是引用。如何删除列表中的项目?
例子:
//initialize struct list, insert 1 struct (this is only done if list is empty)
some_struct* struct_list;
struct_list = (some_struct*)malloc(sizeof(some_struct));
strncpy(struct_list->name, "foo", 4);
struct_list->name[3] = '\0';
typedef struct some_struct
{
char name[MAXLENGTH];
struct some_struct* next;
} some_struct;
some_struct* find_struct(char* name)
{
char* iter;
for (iter = struct_list; iter != NULL; iter = iter->next)
{
if (strcmp(name, iter->name) == 0)
return iter;
}
return NULL;
}
some_struct* name;
name = find_struct("foo"); //since there's only 1 struct, name == struct_list
free(name); //struct_list still contains 1 struct with name "foo"
我确保链表正常工作,它确实找到了名字,但这什么也没做
编辑:为澄清起见,取消链接/链接确实摆脱了结构。但是如果结构中只有 1 个项目,这就不起作用
最佳答案
I made a linked list, and a function that returns the iterator. When assigning the iterator to another pointer and freeing the pointer, it does nothing since it's not a reference. How can I delete the item in the list?
是否引用与任何事情无关。您确实可以通过指向它的 any 指针释放列表节点的内存,但我不知道为什么您认为这会自动将其从列表中删除,即使它是一个引用。相反,节点的前置节点以无效的 next
指针结束,并且取消引用会产生未定义的行为。该 UB 可能采取类似于它在释放内存之前表现出的行为的形式,至少在一段时间内是这样。
你好像把它弄反了。如果您想从列表中删除一个节点,那么这是您的主要目标;释放节点的内存是次要的,只有当您实际上已完成该节点时才合适。从单链表中删除需要找到要删除的节点的前置节点,然后适本地更新其 next
指针。根据您的具体设置方式,删除第一个元素可能是一种特殊情况。
您已经在评论中澄清问题在于从单元素列表中删除唯一元素(或者,我敢打赌,第一个元素,无论列表有多长),扩展我提到的特例。
显然你有一个全局变量
some_struct *struct_list;
有时指向第一个列表节点,列表为空时为null。给定一个指向您要删除的节点的指针,例如您的 find_struc()
函数返回的节点,要从您的列表中删除它,您需要一个遵循以下几行的函数:
void delete_struct(some_struct *to_delete) {
if (struct_list == to_delete) {
// special case: deleting the first element
// ... do something here ...
} else {
some_struct *pred = struct_list;
while (pred && pred->next != to_delete) {
pred = pred->next;
}
if (pred) {
assert(pred->next == to_delete);
pred->next = pred->next->next;
free(to_delete);
}
}
}
那么,显然,问题是“在这里做点什么”应该是什么。但我不明白其中的奥秘或问题是什么。您知道应该发生什么,而且您似乎有能力让它发生:
struct_list = struct_list->next;
free(to_delete);
显然(或者可能不是那么多),您必须设置为 NULL 的变量是您的其余代码查找列表头的变量。
如果你想消除删除第一个元素的特殊情况,那么考虑使用一个虚拟头节点,它甚至不需要动态分配。然后第一个数据承载元素有一个真正的(但非数据承载)前身,你不需要特殊情况。至少还有另一种选择,但是您已经在使用指针方面遇到了足够多的麻烦,所以我将在其他时间留下那个。
关于c - 等价于 C 中的引用指针?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43921882/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!