关于void,今天同学提起,其实以前在《C++编程思想》中看过,内容是C语言中void和其他
类型的相互赋值都是可以的,但是C++中是不允许把void*赋值给其他类型的。做个代码试验如下:
1 /* test.c void*测试 */
2
3 #include <stdio.h>
4 #include <stdlib.h>
5
6
7 typedef struct Test
8 {
9 int test;
10 } test;
11
12 int main()
13 {
14 test *ts = malloc(sizeof(test));
15
16 free(ts);
17
18 return 0;
19 }
编译上述代码:
wanpeng@ubuntu:~$gcc test.c -o test
wanpeng@ubuntu:~$ g++ test.c -o test
test.c: In function ‘int main()’:test.c:11: error: invalid conversion from ‘void’ to ‘test’
可以看到gcc编译没有错误,g++编译错误。
------------------------华丽的分割线----------------------------------------------------------
对于以上情况的解释:
因为C语言对于类型信息不挑剔,所以它允许这种事情。C++不同,类型在C++中是严格的,当类型
信息有任何违例时就不允许。这一点对于C++尤其重要,因为在struct中有成员函数。如果能够在C++
中向struct传递指针而不被阻止,那么我们就能调用struct逻辑上并不存在的成员函数。
无类型包含有类型,比如无类型“车”,你可以说“轿车是车”,“卡车是车”,但是你不能说"车是轿车"或者"车是卡车"^_^
原文链接: https://www.cnblogs.com/wanpengcoder/archive/2010/07/31/1789587.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/13286
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!