大家好,又见面了,我是你们的朋友全栈君。
最近看一段代码有所迷惑,先简单总结一下。有关结构体数组初始化的问题
struct _m_usmart_nametab usmart_nametab[]=
{
#if USMART_USE_WRFUNS==1 //如果使能了读写操作
(void*)read_addr,”u32 read_addr(u32 addr)”,
(void*)write_addr,”void write_addr(u32 addr,u32 val)”,
#endif
(void*)delay_ms,”void delay_ms(u16 nms)”,
(void*)delay_us,”void delay_us(u32 nus)”,
(void*)LCD_Clear,”void LCD_Clear(u16 Color)”,
(void*)LCD_Fill,”void LCD_Fill(u16 xsta,u16 ysta,u16 xend,u16 yend,u16 color)”,
(void*)LCD_DrawLine,”void LCD_DrawLine(u16 x1, u16 y1, u16 x2, u16 y2)”,
(void*)LCD_DrawRectangle,”void LCD_DrawRectangle(u16 x1, u16 y1, u16 x2, u16 y2)”,
(void*)Draw_Circle,”void Draw_Circle(u16 x0,u16 y0,u8 r)”,
(void*)LCD_ShowNum,”void LCD_ShowNum(u16 x,u16 y,u32 num,u8 len,u8 size)”,
(void*)LCD_ShowString,”void LCD_ShowString(u16 x,u16 y,u16 width,u16 height,u8 size,u8 *p)”,
(void*)LCD_ReadPoint,”u16 LCD_ReadPoint(u16 x,u16 y)”,
(void*)fsmc_sram_test_write,”void fsmc_sram_test_write(u8 data,u32 addr)”,
(void*)fsmc_sram_test_read,”u8 fsmc_sram_test_read(u32 addr)”,
(void*)mymalloc,”void *mymalloc(u8 memx,u32 size)”,
(void*)myfree,”void myfree(u8 memx,void *ptr)”,
(void*)mf_mount,”u8 mf_mount(u8 drv)”,
(void*)mf_open,”u8 mf_open(u8*path,u8 mode)”,
(void*)mf_close,”u8 mf_close(void)”,
(void*)mf_read,”u8 mf_read(u16 len)”,
(void*)mf_write,”u8 mf_write(u8*dat,u16 len)”,
(void*)mf_opendir,”u8 mf_opendir(u8* path)”,
(void*)mf_readdir,”u8 mf_readdir(void)”,
(void*)mf_scan_files,”u8 mf_scan_files(u8 * path)”,
(void*)mf_showfree,”u32 mf_showfree(u8 *drv)”,
(void*)mf_lseek,”u8 mf_lseek(u32 offset)”,
(void*)mf_tell,”u32 mf_tell(void)”,
(void*)mf_size,”u32 mf_size(void)”,
(void*)mf_mkdir,”u8 mf_mkdir(u8*pname)”,
(void*)mf_fmkfs,”u8 mf_fmkfs(u8 drv,u8 mode,u16 au)”,
(void*)mf_unlink,”u8 mf_unlink(u8 *pname)”,
(void*)mf_rename,”u8 mf_rename(u8 *oldname,u8* newname)”,
(void*)mf_gets,”void mf_gets(u16 size)”,
(void*)mf_putc,”u8 mf_putc(u8 c)”,
(void*)mf_puts,”u8 mf_puts(u8*c)”,
};
_m_usmart_nametab的结构体如下
//函数名列表
struct _m_usmart_nametab
{
void* func; //函数指针
const u8* name; //函数名(查找串)
};
一开始一直不明白,为什么下边的只有两个参数,而上边的确有那么多,难道不是一一对应?
其实上边的是一个table表,就像 u8 table[]={};
而上边的定义的是一个结构体的数组,其成员很多。但每一个成员应该和结构体类型一致,这只不是定义一个这样结构类型的结构体数组而已。
看下面例子
typedef struct _TEST_T {
int i;
char c[10];
}TEST_T;
TEST_T gst = {1, “12345”};//可以初始化,设置i为1,s为一个字符串.
TEST_T gst = {1};//初始化个数少于实际个数时,只初始化前面的成员。
TEST_Tgst = {.c=“12345”};//有选择的初始化成员。
复合字面量。
gst = (TEST_T){122, “1256”};//这是一个赋值语句,也可以作为初始化。可以出现在程序的任何地方。
当然也可以使用复合字面量来初始化:
gst = (TEST_T){.i=122, .c=”123″};
3、结构体数组
可以用多个大括号括起来:
TEST_T gst[10] = { {},{},{},{}}
也可以初始化其中的一个元素:
TEST_T gst[10] = {[2]={}, [3]={}}
也可以使用复合字面量:
TEST_T gst[10] = {[2].i=0, [3].i={}}
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/161080.html原文链接:https://javaforall.cn