Yiling Lai [MVP—Visual C++][2006,2007]-《深入解析ATL》第二版上市

http://www.china-pub.com/computers/common/info.asp?id=36359

Yiling Lai
Yiling Lai的公告
我在博客园的地址(专注于.Net和WPF)

本Blog上的任何言论仅代表个人观点,与作者所在的公司没有任何关系。本Blog的内容按原样提供,作者不提供任何形式的担保。作者不承担与本站内容相关的所有一切损失。所有原创作品(包括但不限于文章、图片)作者保留一切权利。任何商业用途必须得到作者书面同意。转载必须注名作者和出处。欢迎交流,共同学习一起进步。

《深入解析ATL》第二版上市

最近评论
usfine:Welcome to usfine for Age Of Conan gold and
aoc powerlevewling
usfine:Welcome to our website for wow power leveling and
aoc gold
usfine:Welcome to our website for wow power leveling and
aoc gold
usfine:Welcome to our website for wow power leveling and
aoc gold
usfine:USFINE.COM sell World of Warcraft gold and
wow powerleveling sevise.
文章分类
收藏
    相册
    ATL Internals-1
    Directshow
    WPF
    文章图1
    文章图2
    学校
    系列文章推荐
    手把手教你写Undo/Redo
    友情链接
    Jiangsheng
    Old New Thing
    PiggyXP(小猪)
    何志丹
    博客堂
    快乐鹦鹉
    思归呓语
    蝈蝈
    存档
    软件项目交易
    订阅我的博客
    XML聚合  FeedSky
    订阅到鲜果
    订阅到Google
    订阅到抓虾
    订阅到BlogLines
    订阅到Yahoo
    订阅到GouGou
    订阅到飞鸽
    订阅到Rojo
    订阅到newsgator
    订阅到netvibes

    原创 VC编程经验汇总(三)收藏

    新一篇: MFC的子类化技术 | 旧一篇: VC编程经验汇总(二)

    1. 显示和隐藏标题栏

    方法一:使用API实现

    //隐藏TitleBar
    LONG lStyle = ::GetWindowLong(this->m_hWnd, GWL_STYLE);
    ::SetWindowLong(this->m_hWnd, GWL_STYLE, lStyle & ~WS_CAPTION);
    ::SetWindowPos(this->m_hWnd, NULL, 0, 0, 0, 0,
    SWP_NOSIZE | SWP_NOMOVE | SWP_NOZORDER | SWP_NOACTIVATE | SWP_FRAMECHANGED);

    // 显示TitleBar
    ::SetWindowLong(this->m_hWnd, GWL_STYLE, lStyle | WS_CAPTION);
    ::SetWindowPos(this->m_hWnd, NULL, 0, 0, 0, 0,??SWP_NOSIZE | SWP_NOMOVE | SWP_NOZORDER | SWP_NOACTIVATE | SWP_FRAMECHANGED);
    方法二:使用CWnd成员函数ModifyStyle实现
    // 隐藏TitleBar
    ModifyStyle(WS_CAPTION, 0, SWP_FRAMECHANGED);
    // 显示TitleBar
    ModifyStyle(0, WS_CAPTION, SWP_FRAMECHANGED);

    2 . 怎么用SendMessage()来发送消息来清空它的内容??
    HWND hEditWnd=GetDlgItem(IDC_EDIT1)->GetSafeHwnd();
    ::SendMessage(hEditWnd,WM_SETTEXT,(WPARAM)0,(LPARAM)"");

    3. 弹出文件的属性窗口
    SHELLEXECUTEINFO ShExecInfo ={0};
    ShExecInfo.cbSize = sizeof(SHELLEXECUTEINFO);
    ShExecInfo.fMask = SEE_MASK_INVOKEIDLIST ;
    ShExecInfo.hwnd = NULL;
    ShExecInfo.lpVerb = "properties";
    ShExecInfo.lpFile = "c:\"; //也可以是文件
    ShExecInfo.lpParameters = "";
    ShExecInfo.lpDirectory = NULL;
    ShExecInfo.nShow = SW_SHOW;
    ShExecInfo.hInstApp = NULL;
    ShellExecuteEx(&ShExecInfo);

    4. 删除一个目录下的所有文件

    BOOL DeleteDirectory(LPCTSTR DirName)
    {
      CFileFind tempFind; //声明一个CFileFind类变量,以用来搜索
      char tempFileFind[200]; //用于定义搜索格式
      sprintf(tempFileFind,"%s\\*.*",DirName);
      //匹配格式为*.*,即该目录下的所有文件 
     
      BOOL IsFinded=(BOOL)tempFind.FindFile(tempFileFind);
      //查找第一个文件
       while(IsFinded)
      {
         IsFinded=(BOOL)tempFind.FindNextFile(); //递归搜索其他的文件 
        if(!tempFind.IsDots()) //如果不是"."目录
    {
     char foundFileName[200];
     strcpy(foundFileName,tempFind.GetFileName().GetBuffer(200));
    if(tempFind.IsDirectory()) //如果是目录,则递归地调用
    { //DeleteDirectory
     char tempDir[200];
    sprintf(tempDir,"%s\\%s",DirName,foundFileName);
    DeleteDirectory(tempDir);
    }
    else
     { //如果是文件则直接删除之
     char tempFileName[200];
    sprintf(tempFileName,"%s\\%s",DirName,foundFileName);
    DeleteFile(tempFileName);
    }
    }
    }
     tempFind.Close();
    if(!RemoveDirectory(DirName)) //删除目录
     {
    AfxMessageBox("删除目录失败!",MB_OK);
     return FALSE;
     }
    return TRUE;
    }

    5.? lib和dll文件的区别和联系

    .dll是在你的程序运行的时候才连接的文件,因此它是一种比较小的可执行文件格式,.dll还有其他的文件格式如.ocx等,所有的.dll文件都是可执行。

    .lib是在你的程序编译连接的时候就连接的文件,因此你必须告知编译器连接的lib文件在那里。一般来说,与动态连接文件相对比,lib文件也被称为是静态连接库。当你把代码编译成这几种格式的文件时,在以后他们就不可能再被更改。如果你想使用lib文件,就必须:
    1? 包含一个对应的头文件告知编译器lib文件里面的具体内容
    2? 设置lib文件允许编译器去查找已经编译好的二进制代码

    如果你想从你的代码分离一个dll文件出来代替静态连接库,仍然需要一个lib文件。这个lib文件将被连接到程序告诉操作系统在运行的时候你想用到什么dll文件,一般情况下,lib文件里有相应的dll文件的名字和一个指明dll输出函数入口的顺序表。如果不想用lib文件或者是没有lib文件,可以用WIN32 API函数LoadLibrary、GetProcAddress。事实上,我们可以在Visual C++ IDE中以二进制形式打开lib文件,大多情况下会看到ASCII码格式的C++函数或一些重载操作的函数名字。

    一般我们最主要的关于lib文件的麻烦就是出现unresolved symble 这类错误,这就是lib文件连接错误或者没有包含.c、.cpp文件到工程里,关键是如果在C++工程里用了C语言写的lib文件,就必需要这样包含:
    extern "C"
    {
    #include "myheader.h"
    }
    这是因为C语言写的lib文件没有C++所必须的名字破坏,C函数不能被重载,因此连接器会出错。

    发表于 @ 2004年07月10日 12:21:00|评论(loading...)|编辑

    新一篇: MFC的子类化技术 | 旧一篇: VC编程经验汇总(二)

    评论:没有评论。

    发表评论  


    当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
    Csdn Blog version 3.1a
    Copyright © Yiling Lai