c語言函數初始化
❶ 關於c語言結構體構造函數初始化的問題
#include<iostream>
#include<string>
using std::cout;
using std::string;
class A{
string a;
public:
A(string ab="1wggg"){a=ab;}
string geta(){return a;}
};
void main()
{
A b;
cout<<b.geta();
}
❷ C語言數組的初始化表示方法
不是inta[] 而是例如int a[10]這種。括弧內一定要有個常量數字。
我們可以這樣定義
#define N 5
int a[N]
這表明了數組名為a;數組有5個元素;分別是a[0]到a[4];
對於數組來說;數組是變數的集合,因此數組也具有與變數相同的數據類型和儲存類型。數組的類型就是它所有的變數的類型。在定義數組時,應在數組名前對數組的類型加以確定。如上面的int a[10];則表明了數組內元素均為整形。
所有當表示浮點型可以定義為例如float a[10]。 舉例如下:
(2)c語言函數初始化擴展閱讀
數組名是由用戶命名的C語言標識符,要遵循標識符命名規則。數組名表示數組存儲區域的首地址。數組的首地址也就是第一個元素的地址。數組名是一個地址常量,不能對它賦值。
數組名後是由方括弧括起來的常量表達式,不能使用其他括弧
❸ c語言里變數的"初始化"和"賦初值"一樣嗎
語法上的初始化是指對象定義時,對應的分配空間之後對於值的操作。C語言中,靜態和全局變數默認置0,有初始化列表的復制初始化列表的值到空間(如有不足,剩餘部分置0),局部自動變數可以不初始化(調試器參與時可能被隱式地初始化為其它的值("debug magic number"),例如默認情況下Microsoft C/C++ Debugger會把棧中未初始化的位元組置為0xCC)。
賦初值一般而言是指邏輯意義上的初始化。在C語言中,由於初始化的語法是「=」後加初值,所以「賦初值」基本上就是指語法上的初始化。不過隨著語言的發展,「賦初值」的意義發生了擴大。對有構造語義但又允許不初始化而不產生編譯錯誤的程序設計語言而言,兩者有些微妙的差別。例如C++的構造函數中,用若干個成員名和括弧括起來的初始化值構成的初始化列表是語法上的初始化(也可能是邏輯意義上的初始化,如果沒有被構造函數體內的值覆蓋),而構造函數體中對成員的賦值語句是邏輯上的初始化但不是語法上的初始化。
冰的悸動 錯誤:
1.「程序開始時進行初始化」的說法僅僅適用於靜態或全局變數,而不適於局部自動變數。局部自動變數在函數調用時才能被初始化。
2.「但是根據編譯器的不同有些編譯器會自動賦初值0或其他」——這在ISO/IEC C語言標准中不是由實現定義的行為,如果一個編譯器符合標准,那麼行為就是明確的,即視此初始化的對象是否為全局對象來判斷隱式初始化置0還是不進行初始化——從下面的函數定義來看這里應該var2是全局變數,會被置0。非標准編譯器則另當別論(但是我還沒見過會在這點上沒事找茬的)。
❹ c語言編程中"初始化」是什麼意思啊
初始化就是給一些變數賦值,請看一下語句:
int a = 3;
該語句定義了一個整型變數a,並且給它賦值3,我也可以這樣說,我將整型變數a初始化為3
❺ 什麼是C語言的初始化
就是在定義一個變數的時候給他賦值。
比如:
……
main()
{
int i = 0;//這里就是C的初始化
i = 3;//這里是正常的語句
printf("%d\n", i);
}
如果你不寫int i = 0; 只是 int i;
如果你一旦漏寫了
i = 3;
那麼你再寫 printf("%d", i);
可能出現亂碼,而你找不出來。
如果你寫了i = 0; 那麼你就知道你i 忘記了賦值,可以找到錯誤。
這樣計算機運行的也不那麼郁悶了。