当前位置: 首页 > news >正文

wordpress前台发表文章seocui cn

wordpress前台发表文章,seocui cn,IBM 做网站,刷推广软件以下示例展示了 log_agent 类,它类似于 dataflow_agent 类。 log_agent 类实现异步记录代理,用于将日志消息写入文件和控制台。 log_agent 类使应用程序能够将消息分类为信息性、警告或错误消息。 它还使应用程序能够指定每个日志类别是写入文件、控制台…

以下示例展示了 log_agent 类,它类似于 dataflow_agent 类。 log_agent 类实现异步记录代理,用于将日志消息写入文件和控制台。 log_agent 类使应用程序能够将消息分类为信息性、警告或错误消息。 它还使应用程序能够指定每个日志类别是写入文件、控制台还是同时写入这两者。 本示例将所有日志消息写入文件,并仅将错误消息写入控制台。

消息代理
// log-filter.cpp
// compile with: /EHsc 
#include <windows.h>
#include <agents.h>
#include <sstream>
#include <fstream>
#include <iostream>using namespace concurrency;
using namespace std;// A synchronization primitive that is signaled when its 
// count reaches zero.
class countdown_event
{
public:countdown_event(unsigned int count = 0L): _current(static_cast<long>(count)) {// Set the event if the initial count is zero.if (_current == 0L){_event.set();}}// Decrements the event counter.void signal(){if(InterlockedDecrement(&_current) == 0L){_event.set();}}// Increments the event counter.void add_count(){if(InterlockedIncrement(&_current) == 1L){_event.reset();}}// Blocks the current context until the event is set.void wait(){_event.wait();}private:// The current count.volatile long _current;// The event that is set when the counter reaches zero.event _event;// Disable copy constructor.countdown_event(const countdown_event&);// Disable assignment.countdown_event const & operator=(countdown_event const&);
};// Defines message types for the logger.
enum log_message_type
{log_info    = 0x1,log_warning = 0x2,log_error   = 0x4,
};// An asynchronous logging agent that writes log messages to 
// file and to the console.
class log_agent : public agent
{// Holds a message string and its logging type.struct log_message{wstring message;log_message_type type;};public:log_agent(const wstring& file_path, log_message_type file_messages, log_message_type console_messages): _file(file_path), _file_messages(file_messages), _console_messages(console_messages), _active(0){if (_file.bad()){throw invalid_argument("Unable to open log file.");}}// Writes the provided message to the log.void log(const wstring& message, log_message_type type){  // Increment the active message count._active.add_count();// Send the message to the network.log_message msg = { message, type };send(_log_buffer, msg);}void close(){// Signal that the agent is now closed._closed.set();}protected:void run(){//// Create the dataflow network.//// Writes a log message to file.call<log_message> writer([this](log_message msg){if ((msg.type & _file_messages) != 0){// Write the message to the file.write_to_stream(msg, _file);}if ((msg.type & _console_messages) != 0){// Write the message to the console.write_to_stream(msg, wcout);}// Decrement the active counter._active.signal();});// Connect _log_buffer to the internal network to begin data flow._log_buffer.link_target(&writer);// Wait for the closed event to be signaled._closed.wait();// Wait for all messages to be processed._active.wait();// Close the log file and flush the console._file.close();wcout.flush();// Set the agent to the completed state.done();}private:// Writes a logging message to the specified output stream.void write_to_stream(const log_message& msg, wostream& stream){// Write the message to the stream.wstringstream ss;switch (msg.type){case log_info:ss << L"info: ";break;case log_warning:ss << L"warning: ";break;case log_error:ss << L"error: ";}ss << msg.message << endl;stream << ss.str();}private:   // The file stream to write messages to.wofstream _file;// The log message types that are written to file.log_message_type _file_messages;// The log message types that are written to the console.log_message_type _console_messages;// The head of the network. Propagates logging messages// to the rest of the network.unbounded_buffer<log_message> _log_buffer;// Counts the number of active messages in the network.countdown_event _active;// Signals that the agent has been closed.event _closed;
};int wmain()
{// Union of all log message types.log_message_type log_all = log_message_type(log_info | log_warning  | log_error);// Create a logging agent that writes all log messages to file and error // messages to the console.log_agent logger(L"log.txt", log_all, log_error);// Start the agent.logger.start();// Log a few messages.logger.log(L"===Logging started.===", log_info);logger.log(L"This is a sample warning message.", log_warning);logger.log(L"This is a sample error message.", log_error);logger.log(L"===Logging finished.===", log_info);// Close the logger and wait for the agent to finish.logger.close();agent::wait(&logger);
}

本示例将以下输出写入控制台。

error: This is a sample error message.

此示例还生成 log.txt 文件,其中包含以下文本。

info: ===Logging started.===
warning: This is a sample warning message.
error: This is a sample error message.
info: ===Logging finished.===
编译代码

复制示例代码,并将它粘贴到 Visual Studio 项目中,或粘贴到名为 log-filter.cpp 的文件中,再在 Visual Studio 命令提示符窗口中运行以下命令。

cl.exe /EHsc log-filter.cpp

http://www.tj-hxxt.cn/news/104570.html

相关文章:

  • 淘宝搜券的网站怎么做关键词生成器
  • 哪些做展架图的网站好电商平台建设方案
  • 经常会更换网站域名请收藏个人永久免费自助建站
  • 微商建立网站深圳网络营销推广外包
  • 做网站和做软件一样吗济南做网站比较好的公司
  • 网站管理系统设置发布广告的平台免费
  • wordpress上传图片自动压缩专业seo服务商
  • 中国建设银行网上银行网站特点杭州seo百度关键词排名推广
  • 中国人も日本人も汉字を河源网站seo
  • 个人网站网页模板百度seo sem
  • 如何做响应式网站深圳网站建设推广优化公司
  • dw做的网站成品无线网络优化工程师
  • 华为300mbps无线扩展器设置网站seo双标题软件
  • 仿做购物网站游戏推广员平台
  • wordpress 添加样式表肇庆seo外包公司
  • 建筑设计专业比较好的学校镇江优化推广
  • 海尔电商网站建设方案东莞关键字排名优化
  • 网站突然打不开是什么原因百度广告一级代理
  • 腾讯低代码开发平台seo成创网络
  • 上海市建设工程设计文件审查管理事务中心网站成都网站seo服务
  • 如何进入网站后台管理网站电脑系统优化软件十大排名
  • 拍卖网站建设公司河北网站seo策划
  • 拿自己爱人做网站太原seo推广
  • 网站上的在线答题是怎么做的太仓网站制作
  • 哈尔滨网站建设招聘西安网站到首页排名
  • 怎么自己做网站教程谷歌手机版浏览器官网
  • 大鹏新网站建设aso优化公司
  • 免费做网站页头图烟台百度推广公司
  • 小游戏大全网站自媒体视频剪辑培训班
  • 做环氧地坪工程网站上海seo网站优化软件