在單片機(jī)程序內(nèi)建立鏈表時(shí)候,無法為第三個(gè)節(jié)點(diǎn)開辟空間,現(xiàn)象是,建立鏈表的時(shí)候,第一個(gè)和第二個(gè)節(jié)點(diǎn)均能正確加入,將第三個(gè)節(jié)點(diǎn)加入的時(shí)候,整個(gè)鏈表內(nèi)的為空。原因是:
本文引用地址:http://cafeforensic.com/article/201611/321222.htm單片機(jī)使用Mallco時(shí)候要考慮指定區(qū)域,指定的區(qū)域一定要足夠大。
我們調(diào)試的時(shí)候,就是在IAR中增加堆棧的空間。
在IAR中調(diào)試程序,遇到了這樣的問題,那就是,程序運(yùn)行的過程當(dāng)中,鏈表的內(nèi)容突然為空,讀取鏈表的內(nèi)容失敗。分析了一下原因是,一開始我們是只發(fā)現(xiàn)添加失敗,添加前面的1、2個(gè)單元是成功的,到了第三個(gè)就失敗了,查看了分配空間的程序malloc,malloc分配一個(gè)連續(xù)的空間,如果分配失敗,返回的就是一個(gè)空地址,而我們的鏈表頭剛好等于返回值Token_Head=inset(Token_Head,New_point);,所以鏈表頭“不見了”,自然鏈表就消失了。
刪除節(jié)點(diǎn)后應(yīng)該,釋放空間,要不然,再需要重復(fù)插入刪除的程序中,插入的空間不會(huì)被重新利用,而新插入的又要新的空間,如此反復(fù),再大的空間也不夠用。下面這個(gè)程序放在循環(huán)中,循環(huán)到一定的次數(shù),就會(huì)看到,鏈表突然“全部變?yōu)榭?rdquo;。
void Test_List(void)//建立固定鏈表
{
for(i=0;i<60;i++)
{
strcpy(Mark_Del_Node,Token_Head->MacID);
Token_Head=del( Token_Head,"0005");
struct MacID_Struct *New_point;
New_point=(struct MacID_Struct*)malloc(LEN);
strcpy(New_point->MacID,"0005");
Token_Head=inset(Token_Head,New_point);
}
}
評論