原文地址:http://hatsukiakio.blogspot.com/2009/05/c-explicit.html
c++再轉型別轉換(type cast)的時候有為隱性(implicit)轉換跟顯性(explicit)轉換
這個其實其他語言也有,不過今天針對c++的explicit來探討
考慮下面一段程式碼
#include
using namespace std;
class Integer{
public:
int data;
Integer(int i){data=https://www.it610.com/article/i;
}};
int main() {
Integer i=10;
cout<
【[zz] C++ explicit修飾】
像這樣一段程式碼是可以跑的
Integer i=10;
他會自動去找Integer(int i)的建構子,這樣的一個轉型行為就稱為隱式轉換
然而有時候我們會希望不准使用這種隱式轉換,這時候 explicit修飾就小兵立大功啦
將上面程式改成
#include
using namespace std;
class Integer{
public:
int data;
explicit Integer(int i){data=https://www.it610.com/article/i;
}
};
int main() {
Integer i=10;
cout< return 0;
}
替要防止隱式轉換的建構式將上explicit修飾,此時會編譯不過出現錯誤訊息
error: conversion from ‘int’ to non-scalar type ‘Integer’ requested
這樣用戶端就只能乖乖呼叫建構式了,將程式碼改成如下就能跑了
#include
using namespace std;
class Integer{
public:
int data;
explicit Integer(int i){data=https://www.it610.com/article/i;
}
};
int main() {
Integer i(10);
//呼叫建構式
cout< return 0;
}
推荐阅读
- 个人日记|K8s中Pod生命周期和重启策略
- 学习分享|【C语言函数基础】
- C++|C++浇水装置问题
- 数据结构|C++技巧(用class类实现链表)
- C++|从零开始学C++之基本知识
- 步履拾级杂记|VS2019的各种使用问题及解决方法
- leetcode题解|leetcode#106. 从中序与后序遍历序列构造二叉树
- 动态规划|暴力递归经典问题
- 麦克算法|4指针与队列
- 遇见蓝桥遇见你|小唐开始刷蓝桥(一)2020年第十一届C/C++ B组第二场蓝桥杯省赛真题