1樓:
1.p=a+1可以。表示p指向陣列a的第1行。
2.p=a表示p指向陣列a的第0行。
3.p=a.則*p是陣列a的首地址,這個地址型別是int *。
4.可以定義成(*p)[4],但不能p=a。因為它們型別不一致。
5 *p的值與型別與a[0]相等。
2樓:菜刀剁菜鳥
1. 正確
2.p=a是表示p指向陣列a的第0行;*p指a[0][0];對於a[2][3]不能將定義成(*p)[4]然後將a的地址賦給p指向;*p==a[0][0];(*p)[3]中的3是與a[2][3]相對的,你如果定義a[2][4]那麼這裡就是(*p)[4]
3樓:風之風信子
我本來打了詳細解答,結果只能輸出100個字,你要願意留個郵箱發過去。
int (*p)[3];p先和*結合,
這是一個指標!
然後p再和結合,指向的是陣列。
這個3的意思是這個指標指向的陣列的元素的是3個,明白了嗎?
4樓:
1 不可以 *p沒有初值
2 對的 指向第一行
定義的(*p)[4]和(*p)[3]這兩個是啥區別! 都是陣列,陣列個數不同
c語言指標賦值問題 20
5樓:gta小雞
請分清「指標本身的值」和「指標指向的地址中的值」這兩者的區別。指標本身的值就是地址。
int a = 2;
int *p = &a;
//p = 100; //試圖將指標本身的值修改為100,即令指標p指向記憶體地址100的位置,這是未定義行為
*p = 100; //將指標p指向的地址中的值修改為100,即將a的值修改為100
6樓:匿名使用者
int a =0, *p = &a;
*p = 100; 這個是合法的,修改指標指向記憶體空間內容。
int *p =4;直接把整數賦值給指標變數,由於地址4一般是非法地址,訪問的時候會出現問題,所以一般不會把數值賦值給指標。
7樓:扶明軒轅懋
&是一元運算,取變數地址的操作,間接訪問操作用運算子號*.&他返回運算元的記憶體地址,可以賦給型別合適的指標./
列如int
xint
*pxpx=&x
將x的記憶體地址賦給指標變數px,該賦值語句表示指標px制向變數x,
*運算子與&運算子剛好相反,它也是一遠運算子.用語返回指標指向的記憶體地址中存的值!
c語言指標的賦值問題
8樓:大野瘦子
指標在用要注意初始化,例如:
int *p;
p為指標,地址是未知的,如果直接賦值
*p=a;這樣編譯可以通過,但是會產生警告,p的地址是隨機分配的,這樣對未知的地址賦值很危險,可能會覆蓋掉某些重要資料,所以避免這種危險,在定義指標時注意初始化,也就是賦值。
可以int *p=&a;
或者int *p;
p=&a;
然後再對p進行操作
有錯。注意大小寫,還有
int a=9;
int *p;
p=&a;//這個是指標指向a
*p=8;
這樣就對了。
指標的賦值
int *p;
int a;
int b[1];
p = &a;
p = b;
指標的賦值,「=」的左運算元能夠是*p,也能夠是p。
當「=」的左運算元是*p時,改變的是p所指向的地址存放的資料;
當「=」的左運算元是p時,改變的是p所指向的地址。
陣列的變數名b表示該陣列的首地址,因此p=b;也是正確的
同型別的指標賦值:
int val1 = 18,val2 = 19;
int *p1,*p2;
p1 = &val1;
p2 = &val2;
p1 = p2; //注意啦,p1指向了val2,而沒有指向val1
備註:字串與指標的初始化和賦值
初始化:
char *cp = "abcdefg"; //這個初始化過程,是將指標cp指向字串的首地址,而並非傳遞字串的值。由於,在c語言裡面,沒有總體處理一個字串的機制
賦值:cp = "abcdefg";
*cp=」abcdefg」 ;//錯誤!字串常量傳遞的是它的首地址,不能夠通過*cp改動該字串的值,由於該字串為常量,而它僅僅是簡單的將指標指向該字串常量。
9樓:林聲飄揚
有錯注意:用指標變數前,必須對指標變數賦值如:int i, *p1;
p1=&i;
再如:int a, b;
int *p1, *p2;
*p1=10; *p2=100;
但指標變數未賦值,即指標指向未知地址,這樣是錯誤的因此:絕對不能對未賦值的指標變數作「指向」運算。
int a=9,b;
int *p=&b;//必須加上這一句
*p=a;
*p=8;
這樣就不會產生錯誤
10樓:匿名使用者
注意大小寫!還有
int a=9;
int *p;
p=&a;//這個是指標指向a
*p=8;
這樣就對了。
11樓:七先生是遊戲鬼才
這個還是比較複雜的,你可以學習一下
12樓:匿名使用者
p=&a//把a的地址給指標p
13樓:匿名使用者
語法上沒錯,但可能出現警告,破壞程式其他資料
14樓:渾濃強浩然
p就是一個指標,他指向一個地址,而&p就是p剛才所指向的具體地址,*p是p指向地址裡面的東西。也就是值。*p=&a的意思是把a的地址給了*p,這樣的話p就指向
(指向a的地址)的地址。對指標賦值必須是int*p=null;或者int
*p;p=null。
關於c語言中指標操作字串和指標取值的問題
15樓:
問題一里,如果你想列印字串,printf第二個引數應該是地址而不是地址裡的內容,
如果你想列印一個字元,應該是%c而不是%s應該寫為printf("%s\n",(buf+1)); 或者 printf("%c\n",*(buf+1)); (輸出是e)
問題二和一應該是同樣的錯誤
printf("%s\n",p);是列印整個字串'test'
如果你只列印一個字元,比如s
printf("%c\n",*(p+2));
16樓:匿名使用者
printf輸出字串需要傳入的引數應是你想要開始的地址,把buf+1前面的解引用(*)去掉即可
而*(buf+1)傳遞的是值應該用於輸出字元的情況,如printf("%c\n",*(buf+1));
第二個同理;
推薦一本c語言語法書,c prime plus ,對於這種基本語法解釋的相當清楚
關於C語言指標問題,C語言指標的賦值問題
飛翔的蠍子大叔 關於int p1 123這個問題我看了很多資料,在這裡我發表一點看法,該問題非常好,這是c語言需要規範的地方。int p1 123 是非法操作,指標表示地址,地址 123?我是沒有見過這種操作。地址一般用二進位制 八進位制 十六進位制表示,123表示地址根本就是扯淡!這個語句的目的就...
c 整型指標賦值的問題,C 整型指標賦值的問題
丁文博 你好,你應該通過malloc申請空間,或者是用陣列 現在你這樣p i指向的是一個未知空間,可能是系統需要用到的,不允許你更改內容,即使允許你這樣也是不對的,因為這個空間屬於這個程式,用它就是錯誤的。 你只申請了一個int的空間,卻操作了256個int,當然不對了 韓亭晚區溪 char p a...
c語言問題,陣列與指標,C語言陣列和指標的問題
char a computer a指向一個常量字串,常量字串是不能修改的,而你的for迴圈內要修改a指向的這個常量字串,自然要出錯 char a computer 這個a就是個普通陣列了,它的內容是可以改動的,就不會出錯了 因為 a是個指標啊 所以應該賦值賦地址!所以 應該 char a compu...