【C++中的四种cast转换和隐式类型转换】

C++中的四种cast转换分别是const_cast、static_cast、dynamic_cast和reinterpret_cast。
1. const_cast
用于将const变量转换为非const变量。
2. static_cast
用于各种隐式转换,比如非const转const,void*转指针等,static_cast能用于多态向上转化,如果用于向下转,能成功但是不安全,结果未知。
3. dynamic_cast
用于动态类型转换。只能用于含有虚函数的类,用于类层次间的向上(派生类→基类)和向下(基类→派生类)转化,只能转指针或者引用。向下转换时,如果是非法的,对于指针返回NULL,对于引用抛异常。要深入了解内部转换的原理。
通过在执行到该语句的时候变量的运行类型和要返回的类型是否相同来判断是否能够进行向下转换。
4. reinterpret_cast
几乎什么都可以转,比如将int转指针,可能会出现问题,尽量少用。
5.为什么不使用C的强制转换?
C的强制转换看起来功能强大,什么都可以转,但是转换不够明确,不能进行错误检查,容易出错。
6. 隐式类型转换

  1. 对于内置类型,低精度的变量给高精度的变量赋值会发生隐式类型转换;
int intValue;
double doubleValue;
doubleValue = intValue;//此处发生了隐式类型转换,低精度的int变量转换为了高精度的double变量
  1. 对于只保存在单个参数的构造函数的对象构造来说,函数调用可以直接使用该参数传入,编译器会自动调用其构造函数生成临时对象。
#include <iostream>
using namespace std;

class Person {
public:
	Person(int num) {
		cout << "the parameter is:" << num<<endl;
	}
};

int main(){
	Person obj = 1;
	return 0;
}

运行结果为:

the parameter is:1
### 如何在 IntelliJ IDEA 中配置和使用 Swagger #### 添加 Maven 依赖 为了使 Swagger 能够工作,在 `pom.xml` 文件中需加入特定的依赖项。这可以通过编辑项目的构建文件来完成: ```xml <dependencies> <!-- swagger2 --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.8.0</version> </dependency> <!-- swagger ui --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.8.0</version> </dependency> </dependencies> ``` 这些依赖会引入必要的库用于生成 API 文档以及提供交互式的 UI 页面[^4]。 #### 创建 Swagger 配置类 接着创建一个新的 Java 类用来初始化并配置 Swagger 实例。通常命名为类似于 `SwaggerConfig.java` 的名称,并放置于合适的位置,比如 `config` 包内: ```java import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import springfox.documentation.builders.ApiInfoBuilder; import springfox.documentation.service.ApiInfo; import springfox.documentation.spi.DocumentationType; import springfox.documentation.spring.web.plugins.Docket; @Configuration public class SwaggerConfig { @Bean public Docket api() { return new Docket(DocumentationType.SWAGGER_2) .apiInfo(apiInfo()) .select() .build(); } private ApiInfo apiInfo(){ return new ApiInfoBuilder().title("API文档").description("").termsOfServiceUrl("") .contact(new Contact("", "", "")) .license("").licenseUrl("").version("1.0") .build(); } } ``` 这段代码定义了一个 Spring Bean 来设置 Swagger 的基本信息和其他选项。 #### 启动应用测试 当上述步骤完成后,启动应用程序即可访问默认路径 `/swagger-ui.html` 查看自动生成的 RESTful 接口文档界面。通过浏览器打开该链接可以浏览到所有已暴露出来的 HTTP 请求方法及其参数说明等信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值