關于C++中void*的小作用淺析
本文主要給大家分享了關于C++中void*的一些你可能不了解的小作用,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。
先來看一段代碼:
#include <iostream> #include <string> using namespace std; void o(int* x, void* y){ cout << *x << endl; cout << x << endl; cout << *(int*)y << endl; cout << (int*)y << endl; } int main() { int a = 1, b = 2; o(&a, &b); }
我們看上面的小代碼,函數o傳入兩個地址,一個是a,另一個是b,我們先來看看輸出的情況:
1 0x7038f28b8e98 2 0x7038f28b8e9c
首先最簡單的,*x表示取值,所以輸出了1,接著x表示&a,也就是a的內存地址,所以我們可以看到輸出了一個地址。這些都是基礎,比較簡單。
比較不好理解的地方來了,void* 指針可以代替任意類型的指針,但是呢,在輸出或者調用的時候,你明確采取強制類型轉換的方式,明確地告訴編譯器這是個什么指針。
所以我們先看第四個,第四個(int*) y相當于告訴編譯器這就是一個整數類型的指針,所以就輸出了地址,那么第三個呢,加上*表示的就是取值,不過這里要記得,千萬不要寫成(int*)*y,因為*y是不存在的(在沒有確定類型之前這樣是會報錯的)所以必須注意。
這種傳遞方法可以用于不定類型的指針傳參,但是由于后面解析的時候需要強制類型轉換,所以在執(zhí)行效率上稍微低一些,如果是進行大規(guī)模調用的話那么請謹慎。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
C++中set/multiset容器詳解(附測試用例與結果圖)
set/multiset屬于關聯(lián)式容器,底層結構是用二叉樹實現,下面這篇文章主要給大家介紹了關于C++中set/multiset容器的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-02-02C++17使用折疊表達式實現一個IsAllTrue函數的過程
本文介紹了利用C++17特性實現IsAllTrue函數的方法,詳細講解了從基于初始化列表的初級版本到使用折疊表達式和類型萃取的高級優(yōu)化版本,需要的朋友參考下吧2024-09-09