Ⅰ 51單片機中如何定義比較大的數組變數 比如 char[1024][10]
定義這種大的數組,你首先得有這么大的RAM才可以,不然肯定不好用。內部地址空間就別想了,肯定是放在外部。
如果是常數數組,可以定義到代碼裡面,code char cc[1024][10],這種程序只能讀,不能改,像字型檔點陣一般用這種。
如果有足夠的外部RAM,xdata char xx[1024][10]; 這是把數組定義到外部RAM,需要用MOVX訪問。
Ⅱ 編寫簡單的單片機c語言程序 1、指定數組找最大值 2、排序
#include<stdio.h>
#defineNR10//數組元素個數
/*從主函數開始*/
intmain(intargc,char**argv)
{
intar[NR];
inti;
fprintf(stdout,"請輸入%d個整數: ",NR);
/*獲取並檢查用戶輸入*/
while(1)
{
/*循環獲取NR個數據*/
for(i=0;i<NR;i++)
{
if(fscanf(stdin,"%d",&ar[i])!=1)
{
fprintf(stdout,"輸入錯誤!請重新輸入: ");
while(getchar()!=' ');//丟棄多餘非法字元
break;//打破內層for循環
}
}
/*檢查是否獲取到NR個數據*/
if(i!=NR)
{
continue;
}
else
{
break;
}
}
/*查找最大值和最小值*/
intmax,min;
max=ar[0];//假定第一個數為最大值
min=ar[0];//同時假定也第一個數為最大值
/*從第二個數開始比較查找最值*/
for(i=1;i<NR;i++)
{
if(ar[i]>max)//最大值
{
max=ar[i];
}
if(ar[i]<min)//最小值,不能使用elseif,否則會跳過比較
{
min=ar[i];
}
}
fprintf(stdout,"最大值為:%d最小值為:%d ",max,min);
/*接下來:查找第二大值*/
intsecond;
/*先獲取前兩個數的第一大和第二大值*/
ar[0]>ar[1]?(max=ar[0],second=ar[1]):
(max=ar[1],second=ar[0]);
/*從第2個數開始比較查找*/
for(i=2;i<NR;i++)
{
if(ar[i]>max)//查找最大值:目的是為了比較第二大值
{
second=max;//先把最大值保存給第二大值
max=ar[i];
}
elseif(second<ar[i])//比最大值小的數再看看是否大於第二大值
{
second=ar[i];
}
}
fprintf(stdout,"第二大值為:%d ",second);
return0;
}
(2)單片機最大數組擴展閱讀
一、c語言程序求數組內所有數的和:
1、通過索引的方式就可以訪問到數組內部的元素,索引是從0到數組長度-1。
2、數組點Lenth就是數組的長度。
二、c語言程序冒泡排序:
1、比較相鄰的兩個元素的大小,如果第一個比第二個大就互換一下。
2、然後每一對都做如上操作,如此一來最後一個元素肯定是最大的數了。
3、除了最後一個元素,重復以上步驟。然後倒數第二個就是次大的值了
4、一次按照這個邏輯直到沒有任何數字可以比較了。
Ⅲ 一個單片機能放下多少個數組
= =看你什麼單片機,裡面RAM ROM大小
Ⅳ 51單片機定義一個大數組存在idata與xdata中有什麼區別
存儲的區域不同
idata 是存在 內部RAM 80H--FFH,(對匯編指令來說,不可直接定址,只能間接定址)。
xdata 是存在外部RAM ,有些單片機會在晶元內擴展一些RAM,這部分也要用 xdata,因為是同外部RAM共同編址的,匯編指令中都是用 MOVX來定址。
Ⅳ msp430單片機超大數組問題
如果你擔心程序在初始化之前,看門狗會溢出
你可以用以下代碼在初始化前先關掉看門狗,代碼如下:
__intrinsic sword __low_level_init(void)
{
WDTCTL = WDTPW + WDTHOLD;
return 1;
}
將這個代碼放在主函數外面,如:
#include <msp430.h>
__intrinsic sword __low_level_init(void)
{
WDTCTL = WDTPW + WDTHOLD;
return 1;
}
int main(void)
{
WDTCTL = WDTPW + WDTHOLD; // Stop WDT
//add your code
return 0;
}
Ⅵ 單片機的RAM大小是256B,那麼我想建立一個int 型數組,最多可以建多大的
我不熟悉MSP430單片機,但我想基本原理差不多吧。
首先明確你的數組需要定義的區間,是全局的還是局部的。
如果是全局的就只考慮你程序RAM量分配和MSP430內部RAM情況就可以了。
如果是局部的就要考慮IAR的局部變數存儲方式,看是壓堆棧的形式還是類似KEIL編譯器的內存復用的形式。
如果是壓棧方式存儲局部變數就考慮你程序預留堆棧多少空間,不要在堆棧裡面弄遞歸就行。
如果是內存復用的方式有點浪費了感覺...
Ⅶ 怎麼確定STC單片機可定義數組的大小
試驗一下 unsigned int pdata Data[90],
指定存儲類型為pdata,用寄存器間接定址才能訪問高128位元組的ram
Ⅷ 單片機原理及應用求數組中最大元素時常採用「打擂台」演算法,其編程原理是什麼
電機原理及其他的應用,它的除數的它的最大顏色,我們市場還是可以用打擂台的演算法了,並且他的編程原理我覺得能夠給大家帶來一種更好的是。