C++学习记录(2)

CSize

CSize类

类CSize是对Windows结构SIZE的封装,凡是能用SIZE结构的地方都可以用CSize代替。

结构SIZE表示一个矩形的长度和宽度,其定义为:

typedef struct tagSIZE{

LONG cx;

LONG cy;

} SIZE;

其中 cx、cy分别是宽度和高度。

BEGIN_MESSAGE_MAP(CADHistDoc, CDocument) //{{AFX_MSG_MAP(CADHistDoc)

//}}AFX_MSG_MAP

END_MESSAGE_MAP()

这些都是宏定义,不是函数。
BEGIN_MESSAGE_MAP()END_MESSAGE_MAP()之间添加你的消息响应函数,为每个消息处理函数加入一个入口

SetFilePointer

在一个文件中设置一个新的读取位置。

DWORD WINAPI SetFilePointer(
  __in         HANDLE hFile,
  __in         LONG lDistanceToMove,
  __inout_opt  PLONG lpDistanceToMoveHigh,
  __in         DWORD dwMoveMethod
);

第 1 个参数为要操作的文件句柄;

第 2 个参数是一个 32 位有符号 LONG 型( 32 位系统平台),它代表要移动的距离;

第 3 个参数是指向移动距离值的高序部分,如果这个值设置为 NULL,那么函数只能对长度限制在 (2^31 - 1) 之内的文件进行操作 ,因为这个是有符号的 LONG 型。如果该值非 NULL,那么 lpDistanceToMoveHighlDistanceToMove 合起来就能进行 64 位有符号的移动,而此时这个参数还用于接收文件指针的高序位返回值,而低序位部分由函数的返回值返回。

如果函数返回值不为 INVALID_SET_FILE_POINTER (-1) ,那么说明函数是执行成功的,这时就无需再调用 GetLastError() 函数进行检查。

然 而需要注意的是,INVALID_SET_FILE_POINTER 对于低序位部分是个有效值。也就是说,当设定了lpDistanceToMoveHigh 时,低序位可以寻址到 0xFFFFFFFF 这里,如果函数执行成功那么返回值是 -1,这时因为函数的返回既代表了文件位置又代表了错误代码,所以还需要用 GetLastError() 来确认一下是不是确实发生了错误,如果没有错误那么会返回 NO_ERROR ,若发生了错误,那么返回值就不是位置,而是一个 INVALID_SET_FILE_POINTER 。因此一般情况下,这时会将文件的长度单位限制在 (2^32 - 2) ,这样就避开了要调用 GetLastError() 的必要。

在操作巨型文件时才需要设置第 3 个参数,但是使用 SetFilePointer() 函数来操作巨型文件会显得有些笨拙,对于这种情况可以选择它的增强型 SetFilePointerEx() 则更加容易。

第 4 个参数是移动模式,一共有 3 种:
FILE_BEGIN : 从文件开始的位置进行定位,此时 lDistanceToMove 被解释为无符号型。
FILE_CURRENT : 从文件的当前位置向前或向后移动指针, lDistanceToMove 被解释为有符号型,正数代表向前,负数表示向后。
FILE_END : 从文件的末位向前或向后定位指针。

GetDocument()

视图对象是用来显示文档对象的内容,函数GetDocument()用于获取当前文档对象的指针m_pDocument.而函数OnDraw()是一个虚函数,负责文档对象的数据在用户视图区的显示输出。在向导生成的成员函数OnDraw()中调用了函数GetDocument().通过获取的文档类指针可以在视图中显示文档内容。

为视图窗口添加滚动条

SetScrollSizes(MM_TEXT, sizeTotal);前面的映射有以下,默认用MM_TEXT,后面为大小CSise类型

MM_TEXT 1 pixel Downward
MM_HIMETRIC 0.01 mm Upward
MM_TWIPS 1/1440 in Upward
MM_HIENGLISH 0.001 in Upward
MM_LOMETRIC 0.1 mm Upward
MM_LOENGLISH 0.01 in Upward

GetSafeHwnd

当我们想得到一个窗口对象(CWnd的派生对象)指针的句柄(HWND)时,最安全的方法是使用GetSafeHwnd()函数

typedef WORD near *PWORD; typedef WORD far *LPWORD;

near指针和far指针?

在DOS下(实模式)地址是分段的,每一段的长度为64K字节,刚好是16位(二进制的十六位)。
near指针的长度是16位的,所以可指向的地址范围是64K字节,通常说near指针的寻址范围是64K。
far指针的长度是32位,含有一个16位的基地址和16位的偏移量,将基地址乘以16后再与偏移量相加,(所以实际上far指针是20位的长度。)即可得到far指针的1M字节的偏移量。所以far指针的寻址范围是1M字节,超过了一个段64K的容量。例如一个far指针的段地址为0x7000,偏移量为0x1244,则该指针指向地址0x71224.如果一个far指针的段地址是0x7122,偏移量为0x0004,则该指针也指向地址0x71224。
如果没有指定一个指针是near或far,那么默认是near。所以far指针要显式指定。far指针工作起来要慢一些,因为每次访问一个far指针时,都要将数据段或程序段的数据交换出来。另外,far指针的运算也比较反常,例如上面讲到的far指针指向同一个地址,但是比较的结果却不相同。

什么时候使用far指针?
当使用小代码或小数据存储模式时,不能编译一个有很多代码或数据的程序。因为在64K的一个段中,不能放下所有的代码与数据。为了解决这个问题,需要指定以far函数或far指针来使用这部分的空间(64K以外的空间)。许多库函数就是显式地指定为far函数的形式。far指针通常和farmalloc()这样的内存分配函数一起使用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值