MFC中常用函数.docx

上传人:b****4 文档编号:4673745 上传时间:2022-12-07 格式:DOCX 页数:17 大小:25.97KB
下载 相关 举报
MFC中常用函数.docx_第1页
第1页 / 共17页
MFC中常用函数.docx_第2页
第2页 / 共17页
MFC中常用函数.docx_第3页
第3页 / 共17页
MFC中常用函数.docx_第4页
第4页 / 共17页
MFC中常用函数.docx_第5页
第5页 / 共17页
点击查看更多>>
下载资源
资源描述

MFC中常用函数.docx

《MFC中常用函数.docx》由会员分享,可在线阅读,更多相关《MFC中常用函数.docx(17页珍藏版)》请在冰豆网上搜索。

MFC中常用函数.docx

MFC中常用函数

 

1.IsEmpty()

  函数判断一对象是否初始化,返回布尔值.

  表达式IsEmpty(expression)

  实例:

<%

  Dimi

  response.writeIsEmpty(i)

  %>

返回结果:

true

2.GetAt

  函数原型:

TCHARGetAt(intnIndex)const;

  函数返回值:

字符中第nIndex个字符(从0开始).

  Header:

atlcoll.h

  注意:

nIndex的最大值可由GetUpperBound()得到。

若nIndex小于0或大于最大值,将返回错误。

3.isdigit

  isdigit

  原型:

externintisdigit(charc);

  用法:

#include

  功能:

判断字符c是否为数字

  说明:

当c为数字0-9时,返回非零值,否则返回零。

  附加说明此为宏定义,非真正函数。

 相关函数:

isalnum,isalpha,isxdigit,iscntrl,isgraph,isprint,ispunct,isspace

4.isalnum

  原型:

externintisalnum(intc);

  用法:

#include

  功能:

判断字符变量c是否为字母或数字

  说明:

当c为数字0-9或字母a-z及A-Z时,返回非零值,否则返回零。

5.isalpha

  函数:

isalpha

  原型:

intisalpha(intch)

  用法:

头文件加入#include(旧版本的编译器使用

  功能:

判断字符ch是否为英文字母,当ch为英文字母a-z或A-Z时,在标准c中相当于使用“isupper(ch)||islower(ch)”做测试,返回非零值,否则返回零。

  PS:

{

  isupper

  原型:

externintisupper(intc);

  头文件:

(旧版本的编译器使用

  功能:

判断字符c是否为大写英文字母

  说明:

当参数c为大写英文字母(A-Z)时,返回非零值,否则返回零。

  附加说明:

此为宏定义,非真正函数。

  islower

  islower(测试字符是否为小写字母)

  相关函数

  isalpha,isupper

  表头文件

  #include(旧版本的编译器使用

  定义函数

  intislower(intc)

  函数说明

  检查参数c是否为小写英文字母。

  返回值

  若参数c为小写英文字母,则返回TRUE,否则返回NULL(0)。

  附加说明:

此为宏定义,非真正函数。

  }

  示例:

  /*本函数运行环境VisualC++6.0,测试结果:

通过*/

  #include

  #include

  intmain(void)

  {

  charch;

  inttotal;

  total=0;//初始化

  /*统计字母块*/

  do

  {

  ch=getchar();

  if(isalpha(ch)!

=0)

  total++;

  }while(ch!

='.');//结束符号为.

  printf("Thetotaloflettersis%d\n",total);

  return0;

  }

  /*运行结果*/

  输入:

123456我am侯云江.

  输出:

Thetotaloflettersis2

6.TCHAR

因为C++支持两种字符串,即常规的ANSI编码(使用""包裹)和Unicode编码(使用L""包裹),这样对应的就有了两套字符串字符串处理函数,比如:

strlen和wstrlen,分别用于处理两种字符串

  微软将这两套字符集及其操作进行了统一,通过条件编译(通过_UNICODE和UNICODE宏)控制实际使用的字符集,这样就有了_T("")这样的字符串,对应的就有了_tcslen这样的函数

  为了存储这样的通用字符,就有了TCHAR:

  当没有定义_UNICODE宏时,TCHAR=char,_tcslen=strlen

  当定义了_UNICODE宏时,TCHAR=wchar_t,_tcslen=wstrlen

  当我们定义了UNICODE宏,就相当于告诉了编译器:

我准备采用UNICODE版本。

这个时候,TCHAR就会摇身一变,变成了wchar_t。

而未定义UNICODE宏时,TCHAR摇身一变,变成了unsignedchar。

这样就可以很好的切换宽窄字符集。

tchar可用于双字节字符串,使程序可以用于中日韩等国语言文字处理、显示。

使编程方法简化。

7.GetText函数

  返回数据窗口控件中悬浮在当前行列之上的编辑框中的文本。

在用户修改数据窗口中某项的值时,实际上首先在悬浮在当前项上的编辑框中进行修改,当用户移动输入焦点或程序中使用AcceptText()函数接收用户输入时,用户修改的数据通过有效性规则验证后放入数据窗口的主缓冲区中。

语法:

  dwcontrol.GetText()

参数:

  dwcontrol数据窗口控件名

返回值:

  String函数执行成功时返回悬浮在数据窗口dwcontrol当前行列之上的编辑框中的文本,该文本值或许能、或许不能通过各种有效性检查,即或许可以接收为当前项的值,或许不能接收。

如果数据窗口中没有当前项,则GetText()函数返回空字符串"",如果dwcontrol的值为NULL,则GetText()函数返回NULL。

编辑本段用法:

  显示在数据窗口中的各个数据项的值保存在数据窗口的主缓冲区中。

当用户编辑某项的值时,系统自动把该值传送到漂浮在该项之上的编辑框中,供用户进行修改。

当用户移动输入焦点或程序中使用AcceptText()函数接收用户输入后用户修改的数据通过有效性规则验证时放入数据窗口的主缓冲区中。

  在数据窗口控件的ItemChanged或ItemError事件中不需要调用GetText()函数来得到编辑框中用户输入或修改的内容,此时,可以使用这些事件的data参数得到该内容;要得到数据窗口缓冲区中某项的值,使用与相应列的数据类型相匹配的GetItem系列函数。

编辑本段示例:

  下面的语句得到数据窗口控件中漂浮在当前数据项之上的编辑框的内容并将其保存在变量LName中

  stringLName

  LName=dw_employee.GetText()

  程序例:

  #include

  charbuffer[4096];

  intmain(void)

  {

  inti;

  clrscr();

  for(i=0;i<=20;i++)

  cprintf("Line#%d\r\n",i);

  gettext(1,1,80,25,buffer);

  gotoxy(1,25);

  cprintf("Pressanykeytoclearscreen...");

  getch();

  clrscr();

  gotoxy(1,25);

  cprintf("Pressanykeytorestorescreen...");

  getch();

  puttext(1,1,80,25,buffer);

  gotoxy(1,25);

  cprintf("Pressanykeytoquit...");

  getch();

  return0;

 }

8.SetWindowText

  函数功能:

该函数改变指定窗口的标题栏的文本内容(如果窗口有标题栏)。

如果指定窗口是一个控件,则改变控件的文本内容。

然而,SetWindowText函数不改变其他应用程序中的控件的文本内容。

  函数原型:

BOOLSetWindowText(HWNDhwnd,LPCTSTRlpString);

  参数:

  hWnd:

要改变文本内容的窗口或控件的句柄。

  lpString:

指向一个空结束的字符串的指针,该字符串将作为窗口或控件的新文本。

  返回值:

如果函数成功,返回值为非零;如果函数失败,返回值为零。

若想获得更多错误信息,请调用GetLastError函数。

  备注:

如果目标窗口属于当前进程,SetWindowText函数会使WM_SETTEXT消息发送给指定的窗口或控件。

然而,如果控件是以WS_CAPTION风格创建的列表框控件,SetWindowText函数将为控件设置文本,而不是为列表项设置文本。

  SetWindowText函数不扩展tab字符(ASCII代码0×09),Tab字符以字符‘}’来显示。

 9.进度条颜色设置

在VC里想改变进度条颜色,在网上找了很多方法,都很麻烦,觉得很郁闷。

后来想起在用VB做时,增经用API实现过,很简单。

后来再一查,原来是SendMessage这个函数,几经试验,终于成功,高兴,与大家分享!

      代码如下:

    

      m_Progress1.SendMessage(PBM_SETBKCOLOR,0,RGB(0,0,255));//背景色为蓝色

m_Progress1.SendMessage(PBM_SETBARCOLOR,0,RGB(255,0,0));//前景色为红色

10.VC++中Format函数详解

函数声明

  functionFormat(constFormat:

string;constArgs:

arrayofconst):

string;overload;

函数功能

  事实上Format方法有两种形式,另外一种是三个参数的,主要区别在于它是线程安全的,但并不多用,所以这里只对第一个介绍。

Format参数是一个格式字符串,用于格式化Args里面的值的。

Args是一个变体数组,即它里面可以有多个参数,而且每个参数可以不同。

例如:

  Format("mynameis%6s","wind");

  返回的是:

mynameiswind

函数参数

  Format里面可以写普通的字符串,比如"mynameis",但有些格式指令字符具有特殊意义,比如"%6s"

  格式指令具有以下的形式:

"%"[index":

"]["-"][width]["."prec]type

  它是以"%"开始,而以type结束,type表示一个具体的类型。

中间是用来格式化type类型的指令字符,是可选的。

各个参数的含义与用途如下;

  [type]

  type参数可选的类型有d,u,f,e,g,n,m,p,s,x.

  1)d十进制数,表示一个整型值,u和d一样是整型值,但它是无符号的,而如果它对应的值是负的,则返回时是一个2的32次方减去这个负数的绝对值。

  例如:

Format("thisis%u",-2);

  返回的是:

thisis4294967294

  2)f对应浮点数

  3)e科学表示法,对应整型数和浮点数

  例如:

Format("thisis%e",-2.22);

  返回的是:

thisis-2.220000E+000

  4)g这个只能对应浮点型,且它会将值中多余的数去掉

  例如:

Format("thisis%g",02.200);

  返回的是:

thisis2.2

  5)n只能对应浮点型,将值转化为号码的形式,看一个例子就明白了

  例如:

Format("thisis%n",4552.2176);

  返回的是:

thisis4,552.22

  注意:

一是,只表示到小数后两位

  二是,即使小数没有被截断,它也不会也像整数部分一样有逗号来分开的

  6)m钱币类型,但关于货币类型有更好的格式化方法,这里只是简单的格式化,另外它只对应于浮点值

  例如:

Format("thisis%m",9552.21);

  返回的是:

thisis¥9,552.21

  7)p对应于指针类型,返回的值是指针的地址,以十六进制的形式来表示

  例如:

Format("thisis%p",p);

  返回的是:

thisis0012F548

  8)s对应字符串类型

  9)x必须是一个整形值,以十六进制的形式返回

  例如:

Format("thisis%X",15);

  返回的是:

thisisF

  下面介绍格式化Type的指令:

  [index":

"]:

index指示Args中参数显示的顺序。

  例如:

Format("thisis%d%d",12,13);

  其中第一个%d的索引是0,第二个%d是1,所以字符显示的时候,是这样:

thisis1213

  若定义为:

Format("thisis%1:

d%0:

d",12,13);

  那么返回的字符串就变成了:

thisis1312

  若定义为:

Format("%d%d%d%0:

d%d",1,2,3,4);

  那么将返回的是:

12312

  若想返回的是12314,必须这样定义:

Format("%d%d%d%0:

d%3:

d",1,2,3,4);

  注意:

索引不能超出Args中的个数,不然会引起异常。

  例如:

Format("thisis%2:

d%0:

d",12,13);

  由于Args中只有1213两个数,所以Index只能是0或1,这里为2就错了。

  [width]:

指定将被格式化的值占的宽度。

  例如:

Format("thisis%4d",12);

  返回的是:

thisis12

  如果Width的值小于参数的长度,则没有效果。

  例如:

Format("thisis%1d",12);

  返回的是:

thisis12

  ["-"]:

这个指定参数向左对齐,和[width]合在一起最可以看到效果。

  例如:

Format("thisis%-4d,yes",12);

  返回的是:

thisis12,yes

  ["."prec]:

指定精度,对于浮点数效果最佳。

  例如:

Format('thisis%.2f,1.1234);

  返回的是:

thisis1.12

  又如:

Format('thisis%.7f,1.1234);

  返回的是:

thisis1.1234000

  而对于整型数,如果prec比如整型的位数小,则没有效果,反之比整形值的位数大,则会在整型值的前面以0补之。

  例如:

Format('thisis%.7d,1234);

  返回的是:

thisis0001234

  对于字符型,刚好和整型值相反,如果prec比字符串型的长度大,则没有效果,反之比字符串型的长度小,则会截断尾部的字符。

  例如:

Format('thisis%.2s,1234);

  返回的是:

thisis12

  之前说过的例子:

Format("thisis%e",-2.22);

  返回的是:

thisis-2.220000E+000

  若这样:

Format('thisis%.2e',[-2.22]);就可以解决了!

编辑本段二FormatDateTime的用法

  他的声明为:

  functionFormatDateTime(constFormat:

string;DateTime:

TDateTime):

string;

  overload;

  当然和Format一样还有一种,但这里只介绍常用的第一种

  Format参数是一个格式化字符串。

DateTime是时间类型。

返回值是一种格式化后的

  字符串

  重点来看Format参数中的指令字符

  c以短时间格式显示时间,即全部是数字的表示

  FormatdateTime('c',now);

  输出为:

2004-8-79:

55:

40

  d对应于时间中的日期,日期是一位则显示一位,两位则显示两位

  FormatdateTime('d',now);

  输出可能为1~31

  dd和d的意义一样,但它始终是以两位来显示的

  FormatdateTime('dd',now);

  输出可能为01~31

  ddd显示的是星期几

  FormatdateTime('ddd',now);

  输出为:

星期六

  dddd和ddd显示的是一样的。

  但上面两个如果在其他国家可能不一样。

  ddddd以短时间格式显示年月日

  FormatdateTime('ddddd',now);

  输出为:

2004-8-7

  dddddd以长时间格式显示年月日

  FormatdateTime('dddddd',now);

  输出为:

2004年8月7日

  e/ee/eee/eeee以相应的位数显示年

  FormatdateTime('ee',now);

  输出为:

04(表示04年)

  m/mm/mmm/mmmm表示月

  FormatdateTime('m',now);

  输出为:

8

  FormatdateTime('mm',now);

  输出为08

  FormatdateTime('mmm',now);

  输出为八月

  FormatdateTime('mmmm',now);

  输出为八月

  和ddd/dddd一样,在其他国家可能不同

  yy/yyyy表示年

  FormatdateTime('yy',now);

  输出为04

  FormatdateTime('yyyy',now);

  输出为2004

  h/hh,n/nn,s/ss,z/zzz分别表示小时,分,秒,毫秒

  t以短时间格式显示时间

  FormatdateTime('t',now);

  输出为10:

17

  tt以长时间格式显示时间

  FormatdateTime('tt',now);

  输出为10:

18:

46

  ampm以长时间格式显示上午还是下午

  FormatdateTime('ttampm',now);

  输出为:

10:

22:

57上午

  大概如此,如果要在Format中加普通的字符串,可以用双引号隔开那些

  特定义的字符,这样普通字符串中如果含特殊的字符就不会被显示为

  时间格式啦:

  FormatdateTime('"todayis"c',now);

  输出为:

todayis2004-8-710:

26:

58

  时间中也可以加"-"或""来分开日期:

  FormatdateTime('"todayis"yy-mm-dd',now);

  FormatdateTime('"todayis"yymmdd',now);

  输出为:

todayis04-08-07

  也可以用":

"来分开时间

  FormatdateTime('"todayis"hh:

nn:

ss',now);

  输出为:

todayis10:

32:

23

编辑本段三.FormatFloat的用法

  常用的声明:

  functionFormatFloat(constFormat:

string;Value:

Extended):

string;overload;

  和上面一样Format参数为格式化指令字符,Value为Extended类型

  为什么是这个类型,因为它是所有浮点值中表示范围最大的,如果传入该方法的参数

  比如Double或者其他,则可以保存不会超出范围。

  关键是看Format参数的用法

  0这个指定相应的位数的指令。

  比如:

FormatFloat('000.000',22.22);

  输出的就是022.220

  注意一点,如果整数部分的0的个数小于Value参数中整数的位数,则没有效果

  如:

FormatFloat('0.00',22.22);

  输出的是:

22.22

  但如果小数部分的0小于Value中小数的倍数,则会截去相应的小数和位数

  如:

FormatFloat('0.0',22.22);

  输出的是:

22.2

  也可以在整数0中指定逗号,这个整数位数必须大于3个,才会有逗号出句

  FormatFloat('0,000.0',2222.22);

  输出是:

2,222.2

  如果这样FormatFloat('000,0.0',2222.22);

  它的输出还是:

2,222.2

  注意它的规律

  #和0的用法一样,目前我还没有测出有什么不同。

  FormatFloat('##.##',22.22);

  输出是:

22.00

  E科学表示法,看几个例子大概就明白了

  FormatFloat('0.00E+00',2222.22);

  输出是2.22E+03

  FormatFloat('0000.00E+00',2222.22);

  输出是2222.22E+00

  FormatFloat('00.0E+0',2222.22);

  22.2E+2

  明白了吗,全靠E右边的0来支配的。

编辑本段vb中的format函数

  返回Variant(String),其中含有一个表达式,它是根据格式表达式中的指令来格式化的。

  语法

  Format(expression[,format[,firstdayofweek[,firstweekofyear]]])

  Format函数的语法具有下面几个部分:

  

部分

说明

expression

必要参数。

任何有效的表达式。

format

可选参数。

有效的命名表达式或用户自定义格式表达式。

firstdayofweek

可选参数。

常数,表示一星期的第一天。

firstweekofyear

可选参数。

常数,表示一年的第一周。

 设置

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 初中教育 > 语文

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1