类型安全

C的类型安全

  • C只在局部上下文中表现出类型安全,比如试图从一种结构体的指针转换成另一种结构体的指针时,编译器将会报告错误,除非使用显式类型转换。
  • printf格式输出
    • 上述代码中,使用%d控制整型数字的输出,没有问题,但是改成%f时,明显输出错误,再改成%s时,运行直接报segmentation fault错误
  • malloc函数的返回值
    • malloc是C中进行内存分配的函数,它的返回类型是void即空类型指针,常常有这样的用法char pStr=(char)malloc(100sizeof(char)),这里明显做了显式的类型转换

C++的类型安全

  • 操作符new返回的指针类型严格与对象匹配,而不是void*
  • C中很多以void*为参数的函数可以改写为C++模板函数,而模板是支持类型检查的;
  • 引入const关键字代替#define constants,它是有类型、有作用域的,而#define constants只是简单的文本替换
  • 一些#define宏可被改写为inline函数,结合函数的重载,可在类型安全的前提下支持多种类型,当然改写为模板也能保证类型安全
  • C++提供了dynamic_cast关键字,使得转换过程更加安全,因为dynamic_cast比static_cast涉及更多具体的类型检查。

inline函数()内敛函数

  • 解决一些频繁调用的小函数大量消耗栈空间(栈内存)的问题
  • 将循环中调用inline()修饰的地方换位内敛函数体,避免了频繁调用函数对栈内存重复开辟所带来的消耗。

dynamic_cast

  • dynamic_cast < type-id > ( expression)
  • 该运算符把expression转换成type-id类型的对象。Type-id必须是类的指针、类的引用或者void*;
  • 有类型安全检查
posted @ 2023-02-20 15:23  小秦同学在上学  阅读(19)  评论(0编辑  收藏  举报