C语言中类型转换不匹配的解决方案

 更新时间:2025年12月09日 08:52:56   作者:巧克力拌面  
本文主要介绍了C语言中类型转换不匹配的解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

错误示范:

#include<stdio.h>
#include<stdlib.h>

typedef struct HFTNode
{
	int data;
	struct HFTNode *lchild,*rchild;
}HFTNode,*HFTree; 

int main()
{
	HFTree root=NULL;
	root = (HFTree)malloc( sizeof(HFTNode) );
	root->data = 1;
	root->lchild = NULL;
	root->rchild = NULL;
	printf("%d \n",root->data);
	
	HFTNode node = NULL;
	node = (HFTree)root;
	printf("%d \n",node.data);
	return 0;
}

原因:

上述代码中,

HFTNode node = NULL;

这一行会出现类型不匹配的错误,原因在于:  

此时HFTNode是一个结构体类型(非指针类型),而 NULL通常被定义为 (void*)0,是一个空指针常量。  
现试图将一个指针值(NULL)赋给一个结构体变量(node),这在 C 语言中是不允许的,因为它们的类型不兼容->  修正方法如下:  
如果想定义一个指向HFTNode的指针变量,应该这样写:  

HFTNode *node = NULL;

这样 node就是一个指针,可以赋值为 NULL,也可以指向已经分配的HFTNode 结构体。  

另外,在后面的 node = (HFTree)root; 中,如果 node已经是指针类型,那么直接写 node = root; 即可,因为 root也是 HFTree类型(即HFTNode*),无需强制类型转换。  

修改结果:

#include<stdio.h>
#include<stdlib.h>

typedef struct HFTNode
{
	int data;
	struct HFTNode *lchild,*rchild;
}HFTNode,*HFTree; 

int main()
{
	HFTree root=NULL;
	root = (HFTree)malloc( sizeof(HFTNode) );
	root->data = 1;
	root->lchild = NULL;
	root->rchild = NULL;
	printf("%d \n",root->data);
	
	HFTNode *node = NULL;
	node = root;
	printf("%d \n",node->data);
	return 0;
}

到此这篇关于C语言中类型转换不匹配的解决方案的文章就介绍到这了,更多相关C语言 类型转换不匹配内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++中引用处理的基本方法

    C++中引用处理的基本方法

    引用不是新定义了一个变量,而是给已经存在的变量取了一个别名,编译器不会为引用变量开辟内存空间,他和他引用的变量共用一块内存空间,下面这篇文章主要给大家介绍了关于C++中引用处理的基本方法,需要的朋友可以参考下
    2022-12-12
  • 用C语言实现五子棋小游戏

    用C语言实现五子棋小游戏

    这篇文章主要为大家详细介绍了用C语言实现五子棋小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • C和C++中的基本数据类型的大小及表示范围详解

    C和C++中的基本数据类型的大小及表示范围详解

    这篇文章主要介绍了C和C++中的基本数据类型的大小及表示范围详解,基本数据类型有int、long、long long、float、double、char、string,正文有详细介绍,欢迎参考
    2018-01-01
  • C及C++ 基础循环示例详解

    C及C++ 基础循环示例详解

    这篇文章主要介绍了C及C++ 中的循环示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • ​C++中assign函数的使用

    ​C++中assign函数的使用

    在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价值,感兴趣的可以了解一下
    2025-07-07
  • C++11中移动构造函数案例代码

    C++11中移动构造函数案例代码

    C++11 标准中为了满足用户使用左值初始化同类对象时也通过移动构造函数完成的需求,新引入了 std::move() 函数,它可以将左值强制转换成对应的右值,由此便可以使用移动构造函数,对C++11移动构造函数相关知识感兴趣的朋友一起看看吧
    2023-01-01
  • C++常用的11种设计模式解释及示例代码详解

    C++常用的11种设计模式解释及示例代码详解

    c++常用的设计模式包括单例模式、工厂模式、抽象工厂模式、适配器模式、装饰者模式、代理模式、外观模式、桥接模式、组合模式、享元模式、观察者模式和命令模式等,这篇文章主要介绍了C++常用的11种设计模式解释及示例,需要的朋友可以参考下
    2023-02-02
  • C++ Clock类模拟实现闹钟运行

    C++ Clock类模拟实现闹钟运行

    这篇文章主要为大家详细介绍了C++ Clock类模拟实现闹钟运行,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • c++ 头文件<cwchar>中常见函数的实现代码

    c++ 头文件<cwchar>中常见函数的实现代码

    本文记录了c++ 头文件<cwchar>中常见函数的实现,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-12-12
  • C语言超详细讲解栈的实现及代码

    C语言超详细讲解栈的实现及代码

    栈(stack)又名堆栈,它是一种运算受限的线性表。限定仅在表尾进行插入和删除操作的线性表。这一端被称为栈顶,相对地,把另一端称为栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素
    2022-04-04

最新评论