在 C++ 中返回一個指標
本文將解釋幾種如何從 C++ 函式中返回指標的方法。
使用 std::string::data
函式從 C++ 中的函式返回指標
函式返回型別通常分為三類:值,引用或指標。他們都有自己的最佳用例,在這些情況下
在這些情況下,效能會得到最大的發揮。通常,在 C 語言中,從函式返回指標在 C 語言中更為常見,因為 C++ 提供了更雄辯的概念-使用函式進行傳遞和返回而不復制物件的引用。儘管在某些情況下可能會更好地利用指標,但是我們還是演示一些如何為不同資料結構返回指標值的示例。
在下面的示例程式碼中,我們實現一個函式,該函式引用 std::string
,並返回 char*
,這是基礎資料型別。注意,std::string
類用於包含連續儲存的 char
序列。我們可以使用 data()
內建函式檢索指向序列中第一個字元的指標,並在 return
語句之後傳遞。最後,我們可以根據需要使用返回的指標對 char
陣列進行操作。
#include <iostream>
#include <algorithm>
#include <iterator>
using std::cout; using std::endl;
using std::string; using std::reverse;
char *reverseString(string &s) {
reverse(s.begin(), s.end());
return s.data();
}
int main() {
string str = "This string shall be reversed";
cout << str << endl;
cout << reverseString(str) << endl;
return EXIT_SUCCESS;
}
輸出:
This string shall be reversed
desrever eb llahs gnirts sihT
在 C++ 中使用 &variable
地址符號從函式中返回指標
&
地址運算子的源於 C 語言,C++ 中也使用相同的語義-在其後獲取物件的記憶體地址。但是請注意,當 operator&
被過載時,它的行為略有不同(請參閱頁面)。在這種情況下,我們演示一個函式,該函式將陣列作為其引數之一,並將指標返回到同一陣列。由於指向陣列物件的指標與指向陣列第一個元素的指標相同,因此我們可以使用以下表示法-&arr[0](https://en.cppreference.com/w/cpp/memory/addressof)
返回給定陣列的地址。
#include <iostream>
#include <algorithm>
#include <iterator>
using std::cout; using std::endl;
using std::string; using std::reverse;
int *subtructArray(int arr[], size_t size, int subtrahend)
{
for (size_t i = 0; i < size; ++i) {
arr[i] -= subtrahend;
}
return &arr[0];
}
int main() {
int c_array[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
int num = 3;
auto arr_size = sizeof c_array / sizeof c_array[0];
int *ptr = subtructArray(c_array, arr_size, num);
cout << "c_array = [ ";
for (int i = 0; i < arr_size; ++i) {
cout << ptr[i] << ", ";
}
cout << "\b\b ]" << endl;
return EXIT_SUCCESS;
}
輸出:
c_array = [ -2, -1, 0, 1, 2, 3, 4, 5, 6, 7 ]
或者,可以僅使用功能塊中引用陣列的變數名來重寫先前的程式碼。請注意,即使函式將 int arr[]
作為引數,編譯器也不會複製下面的陣列,而是將指標傳遞給它。我們可以將 arr
名稱傳遞給 return
語句,指標將被返回。
#include <iostream>
#include <algorithm>
#include <iterator>
using std::cout; using std::endl;
using std::string; using std::reverse;
int *subtructArray(int arr[], size_t size, int subtrahend)
{
for (size_t i = 0; i < size; ++i) {
arr[i] -= subtrahend;
}
return arr;
}
int main() {
int c_array[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
int num = 3;
auto arr_size = sizeof c_array / sizeof c_array[0];
int *ptr = subtructArray(c_array, arr_size, num);
cout << "c_array = [ ";
for (int i = 0; i < arr_size; ++i) {
cout << ptr[i] << ", ";
}
cout << "\b\b ]" << endl;
return EXIT_SUCCESS;
}
輸出:
c_array = [ -2, -1, 0, 1, 2, 3, 4, 5, 6, 7 ]
Founder of DelftStack.com. Jinku has worked in the robotics and automotive industries for over 8 years. He sharpened his coding skills when he needed to do the automatic testing, data collection from remote servers and report creation from the endurance test. He is from an electrical/electronics engineering background but has expanded his interest to embedded electronics, embedded programming and front-/back-end programming.
LinkedIn