㈠ C程序為什麼會崩潰
c語言程序運行出現exe停止工作的原因是因為內存溢出和編譯器錯誤。
第一種:內存溢出
內存溢出(out of memory)通俗理解就是內存不夠,程序所需要的內存遠遠超出了主機內安裝的內存所承受大小,就叫內存溢出。系統會提好培示內存溢出,有時候會自動關閉軟體,重啟電腦或者軟體後釋放掉一部分內存又可以正常運行該軟體。
第二種:編譯器錯誤
部分編譯器由於所使用的標准不同(例如在一台機器上使用的可能是C99標准,而另一台機器上使用的是C11標准),或是因為編譯器鏈接庫的損壞,在少數情況下也可能導致程序出現不限於崩潰退出的異常錯誤,通常解決方法是到編譯器官方網站下載最新版的IDE安裝。
舉例說明:
1、除以零。
2、數組越界:int a[3]; a[10000000]=10。
3、指針越界:int * p; p=(int *)malloc(5 * sizeof(int)); *(p+1000000)=10。
4、使用已經釋放的空間:int * p; p=(int *)malloc(5 * sizeof(int));free(p); *p=10。
5、數組開得太大,超出了棧的范圍,造成棧溢出:int a[100000000],沒有開辟內存 List L=(List)malloc(sizeof(struct LNode))。runtimeerror(運行時錯誤)就是程序運行到一半,程序就崩潰了。
(1)怎麼讓c語言崩潰擴展閱讀:
C特有特點:
1、C語言是一個有結構化程序設計、具有變數作用域(variable scope)以及遞歸功能的過程式語言。
2、C語言傳遞參數均是以值傳遞(pass by value),另外也可以傳遞指針(a pointer passed by value)。
3、不同的變數類型可以用結構體(struct)組合在一起。
4、只有32個保留字(缺襪數reserved keywords),使變伏首量、函數命名有更多彈性。
5、部份的變數類型可以轉換,例如整型和字元型變數。
6、通過指針(pointer),C語言可以容易的對存儲器進行低級控制。
7、預編譯處理(preprocessor)讓C語言的編譯更具有彈性。
㈡ 怎樣用C語言編寫一個程序能夠使系統崩潰這是我參加筆試的一個題目,希望高手能給幫助,感激不盡!
//不嘩迅斷地該系統分配內存,直亂嫌此到溢出,為測試這東西害我死機了,多少意思一下哦 ^0 0^
#include<stdio.h>者液
#include<stdlib.h>
int main()
{
int *die;
int t = 1;
while(1)
{
t++;
die = (int*)malloc(1024*1024*t);
}
return 0;
}
㈢ C語言如何停止運行
一般都是用Ctr+c來停止。如果是程序內部的話,可以在main函數裡面使用return,或者用exit()都可以讓程序停止運行。
㈣ c語言編程程序崩潰
同學,你是對c語言的按值傳遞理解不到位。
void s ( int * p_c )
{
p_contemp = ( int * ) malloc ( 5 * sizeof ( int ) )
此處為for循環控制語句依次給數組依次輸入5個數
}
你最初的代碼,s ( int * p_c )中,你用malloc 分配了5個int的空間,把此空間的地址賦給了p_contemp,而沒有賦給指針p_c,所以p_c指向空,在main()中調用a . h_p
會出錯,其為空指針。
而且就算你在s ( int * p_c )中,把malloc 分配的5個int的空間的地址賦給s的參數p_c指針,在main()中,調用a . h_p ,仍然會出錯,a . h_p 仍然為空指針。
因為在c語言中函數的參數是按值傳遞的,即在本題中,你把a . h_p 作為實參傳遞給s ( int * p_c )函數,此時a.h_p為空指針,根據按值傳遞規則,形參p_c將與實a.h_p具有相同的值:空。
在s ( int * p_c )內,( int * ) malloc ( 5 * sizeof ( int ) )執行後,把分配到的空間地址賦給形參p_c,此時形參p_c不為空了,但是根據按值傳遞原則,實參所指向的地址沒變,仍為空。
你所謂的「指針傳遞只要改一個,另一個的內容應該也做了改動」是對的,但是你的代碼寫的不對。你可以在函數外面弄一個指向某個地址的指針,把它傳給一個參數為指針的函數,在函數內修改指針指向的內容,則在函數外實參指針指向的內容也會變。
你也可以考慮用c++的引用傳遞,即把你最初的s ( int * p_c )聲明為s ( int * &p_c ),其它代碼不變,就能看到你想要的效果。