1.
創新互聯建站專注為客戶提供全方位的互聯網綜合服務,包含不限于網站建設、成都網站設計、德陽網絡推廣、成都微信小程序、德陽網絡營銷、德陽企業策劃、德陽品牌公關、搜索引擎seo、人物專訪、企業宣傳片、企業代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們最大的嘉獎;創新互聯建站為所有大學生創業者提供德陽建站搭建服務,24小時服務熱線:18982081108,官方網址:m.kartarina.com
if(y
==
NULL
w
==
NULL
d
==
NULL)這個語法上是對的,但是邏輯上不對,應該任何變量為空指針都不能執行,所以改為if(y
==
NULL
||
w
==
NULL
||
d
==
NULL)
2.
if...else...
的用法問題,else后并不是一定要再加if的。而且if后面一定要有條件。
3.
循環只要是收斂的就可以用,但是要記得初始化
a=a初值;
b=b初值;
epsilon
=較小值;
for(c
=
abs(a-b);
cepsilon
;
c
=
abs(a-b);){
a
=
(a+b)/2;
b
=
sqrt(a*b);
}
4.
要修改y,w,d所指向的值,所以要用指針。否則直接用int
y,w,d的話只能修改函數內部變量,不能帶出函數。(形參和實參的概念)
程序修改如下:
int
convertTime(int
days,
int
*y,
int
*w,
int
*d){
if(days
0){
return
1;
}
else
if(y
==
NULL
||
w
==
NULL
||
d
==
NULL){//去掉多余的if,并修改為||
return
1;
}
else{//去掉多余的if
int
a
=
days%365;
*y
=
days
/
365;
//可以直接這么寫,由于分子分母都是整數,所以這里的除號是做整除
*w
=
a
/
7;
*d
=
a
%
7;
return
0;
}
}
#include stdio.h
void ToUpper(char *p);
int main(void)
{
char s[10];
printf("Please input a string:\n");
scanf("%s",s);//數組名就是數組地址,不用加取址符
ToUpper(s);//自定義函數,在主函數中被調用時,不用加類型
printf("The new string is %s\n",s);
return 0;
}
void ToUpper(char *p)
{
for(;*p!='\0';p++)//這里的 *p=0刪掉,*p=0等價于*p=NULL;也就是說你把指針p變成空指針了,沒有指向了
{
if(*p='a'*p='z')//這里少個指針符
*p=*p-'a'+'A';
}
}
空指針有以下三種用法:
(1)用空指針終止對遞歸數據結構的間接引用。
遞歸是指一個事物由這個事物本身來定義。請看下例:
/*Dumb implementation;should use a loop */
unsigned factorial(unsinged i)
{
if(i=0 || i==1)
{
return 1;
}
else
{
return i * factorial(i-1);
}
}
在上例中,階乘函數factoriai()調用了它本身,因此,它是遞歸的。
一個遞歸數據結構同樣由它本身來定義。最簡單和最常見的遞歸數據結構是(單向)鏈表,鏈表中的每一個元素都包含一個值和一個指向鏈表中下一個元素的指針。請看下例:
struct string_list
{
char *str; /* string(inthiscase)*/
struct string_list *next;
};
此外還有雙向鏈表(每個元素還包含一個指向鏈表中前一個元素的指針)、鍵樹和哈希表等許多整潔的數據結構,一本較好的介紹數據結構的書中都會介紹這些內容。
你可以通過指向鏈表中第一個元素的指針開始引用一個鏈表,并通過每一個元素中指向下一個元素的指針不斷地引用下一個元素;在鏈表的最后一個元素中,指向下一個元素的指針被賦值為NULL,當你遇到該空指針時,就可以終止對鏈表的引用了。請看下例:
while(p!=NULL)
{
/*dO something with p-str*/
p=p-next;
}
請注意,即使p一開始就是一個空指針,上例仍然能正常工作。
(2)用空指針作函數調用失敗時的返回值。
許多C庫函數的返回值是一個指針,在函數調用成功時,函數返回一個指向某一對象的指針;反之,則返回一個空指針。請看下例:
if(setlocale(cat,loc_p)==NULL)
{
/* setlocale()failed;do something*/
/* ...*/
}
返回值為一指針的函數在調用成功時幾乎總是返回一個有效指針(其值不等于零),在調用失敗時則總是返回一個空指針(其值等于零);而返回值為一整型值的函數在調用成功時幾乎總是返回一個零值,在調用失敗時則總是返回一個非零值。請看下例:
if(raise(sig)!=0){
/* raise()failed;do something*/
/* ... */
}
對上述兩類函數來說,調用成功或失敗時的返回值含義都是不同的。另外一些函數在調用成功時可能會返回一個正值,在調用失敗時可能會返回一個零值或負值。因此,當你使用一個函數之前,應該先看一下它的返回值是哪種類型,這樣你才能判斷函數返回值的含義。
(3)用空指針作警戒值
警戒值是標志事物結尾的一個特定值。例如,main()函數的預定義參數argv是一個指針數組,它的最后一個元素(argv[argc])永遠是一個空指針,因此,你可以用下述方法快速地引用argv中的每一個元素:
/*
A simple program that prints all its arguments.
It doesn't use argc ("argument count"); instread.
it takes advantage of the fact that the last
value in argv ("argument vector") is a null pointer.
*/
# include stdio. h
# include assert. h
int
main ( int argc, char * * argv)
{
int i;
printf ("program name = \"%s\"\n", argv[0]);
for (i=l; argv[i] !=NULL; ++i)
printf ("argv[%d] = \"%s\"\n", i, argv[f]);
assert (i = = argc) ; / * see FAQ XI. 5 * /
return 0; / * see FAQ XVI. 4 * /
}
int?swap_any(void?*s,?void?*t,?unsigned?n)
{
int?i;
char?j;
for(i=1;i=n;i++)
{
j=*(char*)s;???//void?*強制轉換成?char?*
*(char*)s=*(char*)t;
*(char*)t=j;
s++;
t++;
}
s-n;?//
t-n;?//和上一句一樣沒有用!!
}
語言定義中說明,?每一種指針類型都有一個特殊值——?“空指針”?——?它與同類型的其它所有指針值都不相同,?它“與任何對象或函數的指針值都不相等”;
不要返回指向棧內存的指針或引用,因為棧內存在函數結束時會被釋放。
指針是個很強大的工具,可是正因為它太強大,所以要操作它不是件易事。操作不當造成的野指針,甚至會引起系統死機等比較嚴重的后果。
如果程序定義了一個指針,就必須要立即讓它指向一個我們設定的空間或者把它設為NULL,如果沒有這么做,那么這個指針里的內容是不可預知的,即不知道它指向內存中的哪個空間(即野指針),它有可能指向的是一個空白的內存區域,可能指向的是已經受保護的區域,甚至可能指向系統的關鍵內存,如果是那樣就糟了,也許我們后面不小心對指針進行操作就有可能讓系統出現紊亂,死機了
不可以.
如果形參為void
*型,那調用的時候也是要實參的.
如果不想用實參,
只能定義成void型.
或者定義成可變參數(...)
新聞名稱:空指針調用函數c語言 c語言函數指針調用函數
當前路徑:http://m.kartarina.com/article22/hgjejc.html
成都網站建設公司_創新互聯,為您提供網站改版、網站內鏈、、虛擬主機、自適應網站、搜索引擎優化
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯