疑惑內容如下:
- 指針也是一種變量
- *操作符的含義
- 指針變量和它所指向的內存塊是二個不同的概念
- *p 含義
- getchar()操作符
- gets和getchar的區別
- strlen
- strcmp比較符
- c語言中聲明和定義的區別
- unsigned/signed的解釋
指針也是一種變量,占有內存空間,用來保存內存地址
操作符的含義(下文拿p舉例)
在指針申明時, *號所申明的變量為指針
在指針使用時, *號表示操作指針所指向內存空間的值
*p相當于通過地址(p變量的值)找到一塊內存;然后操作內存
*p放在等號的左邊,給p所指向的內存賦值
*p放在等號的右邊,通過p里面的內存地址,找到對應的變量,然后取值指針變量和它所指向的內存塊是二個不同的概念
定義一個指針變量p
①在給p賦值時,只會改變p所指向的內存地址(指針變量的值),并沒有改變p所指向的內容(內存塊的值)
②給p賦值*p='a'; 不會改變p所指的內存地址(指針變量的值),只會改變所指的內存塊的值 。
接下來看看間接賦值的理解:
int *p=NULL(int *p,p=NULL);//定義一個指針變量p,他的地址為0;
int a=10;
p=&a;//把a的內存地址賦給p;
*p=20;//改變p所指的內存塊的值,也就是改變了a的值p 含義 :這是一個指針,他也是一個變量,他特殊在,p只能存地址,所以平時我們更改p變量的值,同時就更改了p所指向的內存,當加入花的時候,表示我要去操作或者說我要去訪問這個內存地址了
getchar()操作符的解釋說明
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main() {
int i, j, k;
char str[5];
for (i = 0; i < 5; i++) {
str[i] = getchar();//當程序調用到這里的時候, 程序就等待用戶的輸入,如果用戶輸入的
//不止一個字符,那么就會存入鍵盤的緩沖去中,當用戶點擊回車的時候,程序會自動從
//緩沖區中一個,一個字符的讀取
//程序會在getchar這里一直等待用戶回車,不回車,不會繼續執行下一步
}
for (i = 0, j = 4; i < j; i++,j--) {
k = str[i];
str[i] = str[j];
str[j] = k;
}
for (i = 0; i < 5; i++) {
printf("%c", str[i]);
}
system("pause");
return 0;
}
getchar();//當程序調用到這里的時候, 程序就等待用戶的輸入,如果用戶輸入的,
不止一個字符,那么就會存入鍵盤的緩沖去中,當用戶點擊回車的時候,程序會自動從緩沖區中一個,一個字符的讀取
- gets和getchar的區別:
gets(字符數組):
char str[20]
gets(str);
getchar:獲取輸入的單個字符
strlen 獲取字符串的長度,不包括'\0';
strcmp比較符
char *a = "aBcDeF";
char *b = "AbCdEf";
char *c = "aacdef";
char *d = "aBcDeF";
printf("strcmp(a, b) : %d\n", strcmp(a, b));
printf("strcmp(a, c) : %d\n", strcmp(a, c));
printf("strcmp(a, d) : %d\n", strcmp(a, d));
輸出結果:
strcmp(a, b) : 32
strcmp(a, c) :-31
strcmp(a, d) : 0
雖然給的是字符串,但是比較的時候,是一個一個比較的時候,只要其中一個比較出了大小,就已經可以做出判斷了。上面的小a(97) 和大A(65) 所以 a>b
- c語言中聲明和定義的區別
最根本區別:不需要開辟內存空間的是聲明,需要開辟內存空間的是定義;
extern int b;//我們可以明確的確定它是申明,因為有extern標簽
int main( )
{
int a;//我們可以說它是申明,也可以說它是定義
}
通過上面的代碼我們可以得出下面結論,如果沒有開辟內存空間就是申明,開辟了內存空間就是定義,我們再看下面的一種形式
int main( )
{
extern int a; //這是聲明不是定義。聲明a是一個已定義的外部變量
}
int a; // 是定義,定義a為整型外部變量
這里相同的變量處于同一個.c文件里面,有一個地方對變量a申明了,我們再次去int a 那么這個a就是定義,申明可以有很多次,但是定義只能有一次,如果相同的變量處于同一個.c文件里面,再次去形如int a 這樣去使用它,那就是定義了
-
unsigned/signed的解釋
平常我們定義一個int a 是帶有符號的signed(默認在使用的時候隱藏),它的取值范圍是-32768 到 +32767的整數
我們無符號的unsigned取值范圍是 0到 65535。
在此解釋之前,我們需要了解下基礎知識,看看我們平時存儲的數字在計算機中怎么存儲的,我拿16-bit 計算機為例子:
int singed a = 1 的存儲方式如下;
singed.png
上面表格中最左端的為最高位,最右端的為最低位,signed類型的整數,要去除最高位(符號位),剩下的15位來進行編碼的,而最高位只是用來做標記的,標記的是整數的正負,0表示正,1表示負。
那么我們去除最高位后(符號標記位),負數取值范圍是:-2^15, 正數的取值范圍是:2^15 -1。
針對有符號位的整形 int a = -1 是怎樣存儲在計算機里面的?
存儲方式:原碼---->反碼---->補碼
原碼圖
反碼圖=原碼圖全部數字取反
補碼圖=反碼圖最后一位數字+1
以上就是我們數字在計算機里面的存儲的方式了。
對于unsigned的整數,是沒有符號位的,所以其16位全部用來編碼(沒有符號位了),取值范圍就是從0開始了,0到2^16。
總結下:
signed的取值范圍是從-2^15 到 2^15-1,為啥是15次方呢?因為singed是需要有符號位的,我們計算的時候,需要去除掉最高位符號位。
unsigned的取值范圍是0 到 2^16-1 ,所以整的來說,在正數上面unsigned的取值范圍大于signed
未完待續。。。。