간단한 소스인데 좀..부탁합니다...
/*
안녕하세여..
밑에있는것을 돌리면..*font_datas를 초기화 햇어야 한다는 warnning이 나
오네여..
이전에도 이문제가 있었는데..그때는 잘해결했는데..
기억이 안나네여..
*font_datas를 초기화 하지않구 전역변수 처리했을때는 error가 없는데
consol창이 error가 나네여...누구아시는분..좀.갈쳐주세여..원인을...
*/
#include "stdafx.h"
#define uint8 unsigned char
void copied_array(uint8 *source);
void lcd_putc(uint8 ascii_code);
void font_access(uint8 ascii_code, uint8 *font_datas);
uint8 font_7x16[2][14]=
{
{0x00,0xE0,0x10,0x08,0x08,0x10,0xE0,
0x00,0x03,0x0C,0x08,0x08,0x0C,0x03},
{0x10,0x10,0x08,0xF8,0x00,0x00,0x00,
0x08,0x08,0x08,0x0F,0x08,0x08,0x08}
};
void copied_array(uint8 *source)
{
// source = font_7x16[0];
uint8 i;
for(i=0;i<14;i++)
printf("%o\n",*(source+i) );
}
void lcd_putc(uint8 ascii_code)
{
uint8 i;
uint8 *font_datas;
font_access(ascii_code, font_datas);
for(i=0;i<14;i++)
printf("%d", *(font_datas+i) );
}
void font_access(uint8 ascii_code, uint8 *font_datas)
{
if(ascii_code==1)
font_datas = font_7x16[1];
else
printf("Can not access font fonc\n");
}
int main(int argc, char* argv[])
{
//uint8 hoho= 1;
uint8 *ho;
printf("%s",font_7x16[0]);
printf("Hello World!\n");
//copied_array(&hoho);
ho = font_7x16[0];
copied_array(ho);
lcd_putc(0x01);
return 0;
}
Re: 간단한 소스인데 좀..부탁합니다...
보아하니 Visual-C++에서 작성하신것 같은데...
일단 LINUX에서는 별 에러없이 잘 수행이 되더군요.
소스를 살펴보니 font_datas라는 변수를 포인터로 선언만 해 놓았는데
상당히 불안한 방법입니다.
즉, 포인터 변수로 선언을 한 변수는 메모리를 할당을 해주던가 적당한
배열을 가리켜주어야합니다.
저런식으로 선언만 해주고 무조건 값을 때려 넣는 식의 코드는 엄청나
게 위험하죠.(대부분의 초보자용 책들에서는 아무 꺼리낌없이 사용을
해서 그렇게해도 되는줄알지만... -()
어쨌든 메모리 할당(malloc())을 사용하던가 font_datas를 배열로 잡는
것이 가장 좋습니다.
답변감사합니다..(냉무)
냉무~
댓글 달기