百科问答小站 logo
百科问答小站 font logo



为何void类型指针不能解引用,却可以参与强制类型转换? 第1页

  

user avatar   pansz 网友的相关建议: 
      

你理解错了,编译器知道 void * 的字节数,只是不知道 void 的字节数而已。

void * 跟 void 是两个不同的类型。

void * 的字节数就是地址字长,在64架构里它固定是 64 位长度。这一点是完全确定的。

所以,虽然 void 本身不能参与运算,但 (void *) 作为一个整体却可以参与转化,比如转化为 double(同样是64位),也可以转化为其它的什么。

每个指针本身都是一个值,只不过这个值同时还可以被解读为指向另外一个内存地址的指针而已。void * 指针本身作为一个值,完全是已知长度的确定的值类型,当然可以作为一个整体参与强制类型转换。




  

相关话题

  何时使用 Protected 继承? 
  C++ make_tuple返回值类型,会有效率问题吗? 
  请问,此题使用switch语句编写是否会比if更高效?若想用switch又该如何编写呢? 
  C++中 union 储存的 char 成员能否通过 int 成员读取? 
  C++对比其他语言到底难在哪里?有人对C++异常推崇,除了性能优势,还有什么优点,怎么学好C++? 
  c语言程序经过编译后,每条指令都有一个内存地址,那两个程序如果有相同内存地址的指令怎么办? 
  电脑存在“熟悉”某项任务后运行变快的情况吗? 
  内存为啥要分堆栈在编程里,要是全部只用堆或者全部只用栈,行不行? 
  如何评价"Null reference - my billion-dollar mistake"? 
  C/C++编译器在什么情况下不会重排语句? 

前一个讨论
做个简单的调查,如果三体人给了你一个按钮,你必须要在中国和美国中选择一个彻底抹去,你会选择哪个国家?
下一个讨论
是否任一无穷集合都能分成两个等势的不交集合之并?





© 2025-01-31 - tinynew.org. All Rights Reserved.
© 2025-01-31 - tinynew.org. 保留所有权利