XP桌面和任务栏的隐藏,显示,关闭,注销和重启

2024-04-04 14:38

本文主要是介绍XP桌面和任务栏的隐藏,显示,关闭,注销和重启,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一 桌面

A 桌面的隐藏。首先添加一个按钮,添加消息响应函数,并写上代码

void CMyDlg::OnButton1() 
{// TODO: Add your control notification handler code hereHWND desktop = ::FindWindow("Shell_TrayWnd",NULL);if(desktop!=NULL){::ShowWindow(desktop,SW_HIDE);}}

B 桌面的显示。首先添加一个按钮,添加消息响应函数,并写上代码

void CMyDlg::OnButton2() 
{// TODO: Add your control notification handler code hereHWND desktop = ::FindWindow("Shell_TrayWnd",NULL);if(desktop!=NULL){::ShowWindow(desktop,SW_SHOW);}}


二 任务栏

A 任务栏的隐藏。首先添加一个按钮,添加消息响应函数,并写上代码

void CMyDlg::OnButton3() 
{// TODO: Add your control notification handler code hereHWND mask = ::FindWindow("ProgMan",NULL);if(mask!=NULL){::ShowWindow(mask,SW_HIDE);}	}

B任务栏的显示。首先添加一个按钮,添加消息响应函数,并写上代码

void CMyDlg::OnButton4() 
{// TODO: Add your control notification handler code hereHWND mask = ::FindWindow("ProgMan",NULL);if(mask!=NULL){::ShowWindow(mask,SW_SHOW);}}

三 退出按钮。并且添加消息响应函数

void CMyDlg::OnButton5() 
{// TODO: Add your control notification handler code hereOnOK();}


一  关闭计算机。添加一个按钮,并且添加消息响应函数

void CShutWindowDlg::OnButton4() 
{// TODO: Add your control notification handler code hereExitWindowsEx(EWX_POWEROFF,0);}


二  重启计算机。添加一个按钮,并且添加消息响应函数

void CShutWindowDlg::OnButton5() 
{// TODO: Add your control notification handler code hereExitWindowsEx(EWX_REBOOT,0);
}



三  注销计算机。添加一个按钮,并且添加消息响应函数

void CShutWindowDlg::OnButton6() 
{// TODO: Add your control notification handler code hereExitWindowsEx(EWX_LOGOFF,0);}

Windows网络编程

对于许多初学者来说,网络通信程序的开发,普遍的一个现象就是觉得难以入手。许多概念,诸如:同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)等,初学者往往迷惑不清,只知其所以而不知起所以然。 
       同步方式指的是发送方不等接收方响应,便接着发下个数据包的通信方式;而异步指发送方发出数据后,等收到接收方发回的响应,才发下一个数据包的通信方式。 
      阻塞套接字是指执行此套接字的网络调用时,直到成功才返回,否则一直阻塞在此网络调用上,比如调用recv()函数读取网络缓冲区中的数据,如果没有数据到达,将一直挂在recv()这个函数调用上,直到读到一些数据,此函数调用才返回;而非阻塞套接字是指执行此套接字的网络调用时,不管是否执行成功,都立即返回。比如调用recv()函数读取网络缓冲区中数据,不管是否读到数据都立即返回,而不会一直挂在此函数调用上。在实际Windows网络通信软件开发中,异步非阻塞套接字是用的最多的。平常所说的C/S(客户端/服务器)结构的软件就是异步非阻塞模式的。 
       对于这些概念,初学者的理解也许只能似是而非,我将用一个最简单的例子说明异步非阻塞Socket的基本原理和工作机制。目的是让初学者不仅对Socket异步非阻塞的概念有个非常透彻的理解,而且也给他们提供一个用Socket开发网络通信应用程序的快速入门方法。操作系统是Windows 98(或NT4.0),开发工具是Visual C++6.0。 
       MFC提供了一个异步类CAsyncSocket,它封装了异步、非阻塞Socket的基本功能,用它做常用的网络通信软件很方便。但它屏蔽了Socket的异步、非阻塞等概念,开发人员无需了解异步、非阻塞Socket的原理和工作机制。因此,建议初学者学习编网络通信程序时,暂且不要用MFC提供的类,而先用Winsock2  API,这样有助于对异步、非阻塞Socket编程机制的理解。 
       为了简单起见,服务器端和客户端的应用程序均是基于MFC的标准对话框,网络通信部分基于Winsock2 API实现。 
       先做服务器端应用程序。 
       用MFC向导做一个基于对话框的应用程序SocketSever,注意第三步中不要选上Windwos Sockets选项。在做好工程后,创建一个SeverSock,将它设置为异步非阻塞模式,并为它注册各种网络异步事件,然后与自定义的网络异步事件联系上,最后还要将它设置为监听模式。在自定义的网络异步事件的回调函数中,你可以得到各种网络异步事件,根据它们的类型,做不同的处理。下面将详细介绍如何编写相关代码。 
       在SocketSeverDlg.h文件的类定义之前增加如下定义: 
      #define  NETWORK_EVENT  WM_USER+166  file://定义网络事件 
     
       SOCKET ServerSock; file://服务器端Socket 
      在类定义中增加如下定义: 
      class CSocketSeverDlg : CDialog 
     { 
                 … 
      public: 
         SOCKET ClientSock[CLNT_MAX_NUM]; file://存储与客户端通信的Socket的数组 

         /*各种网络异步事件的处理函数*/ 
       void OnClose(SOCKET CurSock);   file://对端Socket断开 
        void OnSend(SOCKET CurSock);   file://发送网络数据包 
       void OnReceive(SOCKET CurSock); file://网络数据包到达 
       void OnAccept(SOCKET CurSock);  file://客户端连接请求 

        BOOL InitNetwork();  file://初始化网络函数 
         void OnNetEvent(WPARAM wParam, LPARAM lParam); file://异步事件回调函数 
                … 
     }; 
         
      在SocketSeverDlg.cpp文件中增加消息映射,其中OnNetEvent是异步事件回调函数名: 
               ON_MESSAGE(NETWORK_EVENT,OnNetEvent) 
      定义初始化网络函数,在SocketSeverDlg.cpp文件的OnInitDialog()中调此函数即可。 
      BOOL CSocketSeverDlg::InitNetwork() 
      { 
           WSADATA wsaData; 

          file://初始化TCP协议 
          BOOL ret = WSAStartup(MAKEWORD(2,2), &wsaData); 
         if(ret != 0) 
          { 
                MessageBox("初始化网络协议失败!"); 
               return FALSE; 
          } 

          file://创建服务器端套接字 
          ServerSock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); 
           if(ServerSock == INVALID_SOCKET) 
          { 
               MessageBox("创建套接字失败!"); 
              closesocket(ServerSock); 
              WSACleanup(); 
               return FALSE; 
          } 

          file://绑定到本地一个端口上 
          sockaddr_in localaddr; 
          localaddr.sin_family = AF_INET; 
          localaddr.sin_port = htons(8888);  file://端口号不要与其他应用程序冲突 
          localaddr.sin_addr.s_addr = 0; 
         if(bind(ServerSock ,(struct sockaddr*)&localaddr,sizeof(sockaddr)) 
                                          = = SOCKET_ERROR) 
         { 
               MessageBox("绑定地址失败!"); 
               closesocket(ServerSock); 
               WSACleanup(); 
               return FALSE; 
         } 

         file://将SeverSock设置为异步非阻塞模式,并为它注册各种网络异步事件,其 中   m_hWnd       
         file://为应用程序的主对话框或主窗口的句柄 
        if(WSAAsyncSelect(ServerSock, m_hWnd, NETWORK_EVENT, 
              FD_ACCEPT | FD_CLOSE | FD_READ | FD_WRITE) == SOCKET_ERROR) 
         { 
               MessageBox("注册网络异步事件失败!"); 
               WSACleanup(); 
               return FALSE; 
         } 
         listen(ServerSock, 5); file://设置侦听模式 
        return TRUE; 
     } 

     下面定义网络异步事件的回调函数 
     void CSocketSeverDlg::OnNetEvent(WPARAM wParam, LPARAM lParam) 
     { 
        file://调用Winsock API函数,得到网络事件类型 
        int iEvent = WSAGETSELECTEVENT(lParam); 
           
        file://调用Winsock API函数,得到发生此事件的客户端套接字 
        SOCKET CurSock= (SOCKET)wParam; 

        switch(iEvent) 
        { 
        case FD_ACCEPT:      file://客户端连接请求事件 
                OnAccept(CurSock); 
                break; 
        case FD_CLOSE:       file://客户端断开事件: 
                OnClose(CurSock); 
                break; 
        case FD_READ:        file://网络数据包到达事件 
                OnReceive(CurSock); 
                break; 
         case FD_WRITE:      file://发送网络数据事件 
                OnSend(CurSock); 
                break; 
         default: break; 
         } 
     } 
     
      以下是发生在相应Socket上的各种网络异步事件的处理函数,其中OnAccept传进来的参数是服务器端创建的套接字,OnClose()、OnReceive()和OnSend()传进来的参数均是服务器端在接受客户端连接时新创建的用与此客户端通信的Socket。 
    void CSocketSeverDlg::OnAccept(SOCKET CurSock) 
    { 
         file://接受连接请求,并保存与发起连接请求的客户端进行通信Socket 
     file://为新的socket注册异步事件,注意没有Accept事件 
    } 

    void CSocketSeverDlg::OnClose(SOCET CurSock) 
    { 
        file://结束与相应的客户端的通信,释放相应资源 
    } 

    void CSocketSeverDlg::OnSend(SOCET CurSock) 
    { 
        file://在给客户端发数据时做相关预处理 
    } 

    void CSocketSeverDlg::OnReceive(SOCET CurSock) 
    { 
        file://读出网络缓冲区中的数据包 
    }         
         
       用同样的方法建立一个客户端应用程序。初始化网络部分,不需要将套接字设置为监听模式。注册异步事件时,没有FD_ACCEPT,但增加了FD_CONNECT事件,因此没有OnAccept()函数,但增加了OnConnect()函数。向服务器发出连接请求时,使用connect()函数,连接成功后,会响应到OnConnect()函数中。下面是OnConnect()函数的定义,传进来的参数是客户端Socket和服务器端发回来的连接是否成功的标志。 
void CSocketClntDlg::OnConnect(SOCKET CurSock, int error) 

    if(0 = = error) 
    { 
    if(CurSock = = ClntSock) 
     MessageBox("连接服务器成功!"); 
   } 

    定义OnReceive()函数,处理网络数据到达事件; 
    定义OnSend()函数,处理发送网络数据事件; 
    定义OnClose()函数,处理服务器的关闭事件。 
             
       以上就是用基于Windows消息机制的异步I/O模型做服务器和客户端应用程序的基本方法。另外还可以用事件模型、重叠模型或完成端口模型,读者可以参考有关书籍。 
       在实现了上面的例子后,你将对Winsock编网络通信程序的机制有了一定的了解。接下来你可以进行更精彩的编程, 不仅可以在网上传输普通数据,而且还以传输语音、视频数据,你还可以自己做一个网络资源共享的服务器软件,和你的同学在实验室的局域网里可以共同分享你的成果。







这篇关于XP桌面和任务栏的隐藏,显示,关闭,注销和重启的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/876058

相关文章

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

lvgl8.3.6 控件垂直布局 label控件在image控件的下方显示

在使用 LVGL 8.3.6 创建一个垂直布局,其中 label 控件位于 image 控件下方,你可以使用 lv_obj_set_flex_flow 来设置布局为垂直,并确保 label 控件在 image 控件后添加。这里是如何步骤性地实现它的一个基本示例: 创建父容器:首先创建一个容器对象,该对象将作为布局的基础。设置容器为垂直布局:使用 lv_obj_set_flex_flow 设置容器

C# dateTimePicker 显示年月日,时分秒

dateTimePicker默认只显示日期,如果需要显示年月日,时分秒,只需要以下两步: 1.dateTimePicker1.Format = DateTimePickerFormat.Time 2.dateTimePicker1.CustomFormat = yyyy-MM-dd HH:mm:ss Tips:  a. dateTimePicker1.ShowUpDown = t

C#关闭指定时间段的Excel进程的方法

private DateTime beforeTime;            //Excel启动之前时间          private DateTime afterTime;               //Excel启动之后时间          //举例          beforeTime = DateTime.Now;          Excel.Applicat

恶意PNG:隐藏在图片中的“恶魔”

<img src="https://i-blog.csdnimg.cn/blog_migrate/bffb187dc3546c6c5c6b8aa18b34b962.jpeg" title="214201hhuuhubsuyuukbfy_meitu_1_meitu_2.jpg"/></strong></span><

Golang服务平滑重启

与重载配置相同的是我们也需要通过信号来通知server重启,但关键在于平滑重启,如果只是简单的重启,只需要kill掉,然后再拉起即可。平滑重启意味着server升级的时候可以不用停止业务。 我们先来看下Github上有没有相应的库解决这个问题,然后找到了如下三个库: facebookgo/grace - Graceful restart & zero downtime deploy for G

Flink任务重启策略

概述 Flink支持不同的重启策略,以在故障发生时控制作业如何重启集群在启动时会伴随一个默认的重启策略,在没有定义具体重启策略时会使用该默认策略。如果在工作提交时指定了一个重启策略,该策略会覆盖集群的默认策略默认的重启策略可以通过 Flink 的配置文件 flink-conf.yaml 指定。配置参数 restart-strategy 定义了哪个策略被使用。常用的重启策略: 固定间隔 (Fixe

argodb自定义函数读取hdfs文件的注意点,避免FileSystem已关闭异常

一、问题描述 一位同学反馈,他写的argo存过中调用了一个自定义函数,函数会加载hdfs上的一个文件,但有些节点会报FileSystem closed异常,同时有时任务会成功,有时会失败。 二、问题分析 argodb的计算引擎是基于spark的定制化引擎,对于自定义函数的调用跟hive on spark的是一致的。udf要通过反射生成实例,然后迭代调用evaluate。通过代码分析,udf在