Windows程序设计中的小问题

时间:2021-08-04 17:39:07
 最近在看《windows程序设计一书》,看书中遇到个小细节问题!

问题在第四章:文本输出

第四章有个 sysmets1.c 小程序

代码如下:

TextOut(hdc,0,cyChar * c, sysmetrics[c].szLabel, lstrlen(sysmetrics[c].szLabel));

sysmetrics是个数组,sysmetrics[c].szLabel为什么就得到数组中的字符串了呢?
结构体:
struct 
{
  int iIndex;
   TCHAR * szLabel;
   TCHAR * szDesc;
}
sysmetrics[] = 
{
.....

}
希望看过windows程序设计的坛友给我解答一下!
 

7 个解决方案

#1


TextOut(hdc,0,cyChar * c, sysmetrics[c].szLabel, lstrlen(sysmetrics[c].szLabel));//此c是前面参数中的c吗?
 

#2


struct 数组

#3


 TCHAR 是一个宽字符类型
szLabel是指向这个类型的指针
sysmetrics[c].szLabel是直接就指向STRING的首地址了,然后就输出字符创
我也刚刚在学windows编程,刚好学到第四章,哈哈

#4


==
struct 
 {
   int iIndex;
    TCHAR * szLabel;
    TCHAR * szDesc;
 }struct_xxxx;

struct struct_xxxx 数组[xx];

#5


VS IDE中,在不明白的符号上点鼠标右键,选转到定义。

#6


大家好!
结构体的定义是这样的

struct
{
     int     iIndex ;
     TCHAR * szLabel ;
     TCHAR * szDesc ;
}
sysmetrics [] =
{
     SM_CXSCREEN,             TEXT ("SM_CXSCREEN"),              
                              TEXT ("Screen width in pixels"),
     SM_CYSCREEN,             TEXT ("SM_CYSCREEN"),              
                              TEXT ("Screen height in pixels"),


循环:

for (i = 0; i <NUMLINES; i++)
{
  TextOut(hdc,0,cyChar * i,
  sysmetrics[i].szLabel,
  lstrlen(sysmetrics[i].szLabel));
  TextOut(hdc,22 *cxCaps,
  cyChar * i, 
  sysmetrics[i].szDesc,
  lstrlen(sysmetrics[i].szDesc));
  SetTextAlign(hdc, TA_RIGHT | TA_TOP);
  TextOut(hdc, 22 * cxCaps + 40 *cyChar,
  cyChar *i,
  szstr,
  wsprintf(szstr,TEXT("%5d"),GetSystemMetrics(sysmetrics[i].iIndex)));
}


sysmetrics是个数组,sysmetrics[i].szLabel为什么就得到数组中的字符串了呢?
希望有详细的解答,谢谢

#7


sysmetrics[i].szLabel
sysmetrics是结构数组
sysmetrics[i]是结构数组sysmetrics的第i个元素
sysmetrics[i].szLabel是结构数组sysmetrics的第i个元素即一个结构中的szLabel分量。
且sysmetrics[0].szLabel指向常量字符串TEXT ("SM_CXSCREEN")的首地址
且sysmetrics[1].szLabel指向常量字符串TEXT ("SM_CYSCREEN")的首地址

VC调试时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习汇编以及C和汇编的对应关系。
从汇编的角度理解和学习C语言的指针,原本看似复杂的东西就会变得非常简单!
指针即地址。“地址又是啥?”“只能从汇编语言和计算机组成原理的角度去解释了。”

这辈子不看内存地址和内存值;只画链表、指针示意图,画堆栈示意图,画各种示意图,甚至自己没画过而只看过书上的图……能从本质上理解指针、理解函数参数传递吗?本人深表怀疑!
这辈子不种麦不收麦不将麦粒拿去磨面;只吃馒头、吃面条、吃面包、……甚至从没看过别人怎么蒸馒头,压面条,烤面包,……能从本质上理解面粉、理解面食吗?本人深表怀疑!!

提醒:
“学习用汇编语言写程序”

“VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习C和汇编的对应关系。”
不是一回事!

不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!

有人说一套做一套,你相信他说的还是相信他做的?
其实严格来说这个世界上古往今来所有人都是说一套做一套,不是吗?

不要写连自己也预测不了结果的代码!

电脑内存只是一个一维二进制字节数组及其对应的二进制地址;
人脑才将电脑内存中的这个一维二进制字节数组及其对应的二进制地址的某些部分看成是函数、函数参数、堆、栈、数组、指针、数组指针、指针数组、数组的数组、指针的指针、二维数组、……


#1


TextOut(hdc,0,cyChar * c, sysmetrics[c].szLabel, lstrlen(sysmetrics[c].szLabel));//此c是前面参数中的c吗?
 

#2


struct 数组

#3


 TCHAR 是一个宽字符类型
szLabel是指向这个类型的指针
sysmetrics[c].szLabel是直接就指向STRING的首地址了,然后就输出字符创
我也刚刚在学windows编程,刚好学到第四章,哈哈

#4


==
struct 
 {
   int iIndex;
    TCHAR * szLabel;
    TCHAR * szDesc;
 }struct_xxxx;

struct struct_xxxx 数组[xx];

#5


VS IDE中,在不明白的符号上点鼠标右键,选转到定义。

#6


大家好!
结构体的定义是这样的

struct
{
     int     iIndex ;
     TCHAR * szLabel ;
     TCHAR * szDesc ;
}
sysmetrics [] =
{
     SM_CXSCREEN,             TEXT ("SM_CXSCREEN"),              
                              TEXT ("Screen width in pixels"),
     SM_CYSCREEN,             TEXT ("SM_CYSCREEN"),              
                              TEXT ("Screen height in pixels"),


循环:

for (i = 0; i <NUMLINES; i++)
{
  TextOut(hdc,0,cyChar * i,
  sysmetrics[i].szLabel,
  lstrlen(sysmetrics[i].szLabel));
  TextOut(hdc,22 *cxCaps,
  cyChar * i, 
  sysmetrics[i].szDesc,
  lstrlen(sysmetrics[i].szDesc));
  SetTextAlign(hdc, TA_RIGHT | TA_TOP);
  TextOut(hdc, 22 * cxCaps + 40 *cyChar,
  cyChar *i,
  szstr,
  wsprintf(szstr,TEXT("%5d"),GetSystemMetrics(sysmetrics[i].iIndex)));
}


sysmetrics是个数组,sysmetrics[i].szLabel为什么就得到数组中的字符串了呢?
希望有详细的解答,谢谢

#7


sysmetrics[i].szLabel
sysmetrics是结构数组
sysmetrics[i]是结构数组sysmetrics的第i个元素
sysmetrics[i].szLabel是结构数组sysmetrics的第i个元素即一个结构中的szLabel分量。
且sysmetrics[0].szLabel指向常量字符串TEXT ("SM_CXSCREEN")的首地址
且sysmetrics[1].szLabel指向常量字符串TEXT ("SM_CYSCREEN")的首地址

VC调试时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习汇编以及C和汇编的对应关系。
从汇编的角度理解和学习C语言的指针,原本看似复杂的东西就会变得非常简单!
指针即地址。“地址又是啥?”“只能从汇编语言和计算机组成原理的角度去解释了。”

这辈子不看内存地址和内存值;只画链表、指针示意图,画堆栈示意图,画各种示意图,甚至自己没画过而只看过书上的图……能从本质上理解指针、理解函数参数传递吗?本人深表怀疑!
这辈子不种麦不收麦不将麦粒拿去磨面;只吃馒头、吃面条、吃面包、……甚至从没看过别人怎么蒸馒头,压面条,烤面包,……能从本质上理解面粉、理解面食吗?本人深表怀疑!!

提醒:
“学习用汇编语言写程序”

“VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习C和汇编的对应关系。”
不是一回事!

不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!

有人说一套做一套,你相信他说的还是相信他做的?
其实严格来说这个世界上古往今来所有人都是说一套做一套,不是吗?

不要写连自己也预测不了结果的代码!

电脑内存只是一个一维二进制字节数组及其对应的二进制地址;
人脑才将电脑内存中的这个一维二进制字节数组及其对应的二进制地址的某些部分看成是函数、函数参数、堆、栈、数组、指针、数组指针、指针数组、数组的数组、指针的指针、二维数组、……