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

做网站与数据库的关系seo优化网站建设公司

做网站与数据库的关系,seo优化网站建设公司,自己做网站出口,重庆外贸网站建设以下示例展示了 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.yayakq.cn/news/494316/

相关文章:

  • 有没有专门做售楼部包装的网站微信公众号这么创建
  • 企业建网站平台小程序推广渠道
  • 寿光网站建设多少钱长沙人才招聘网最新
  • 网站设计外包协议怎样做商业网站平台
  • 深圳互助资金盘网站开发wordpress如何看网页地址
  • 商城网站开发报山东省住房与建设厅网站首页
  • 品牌网站策划淘宝网站框架
  • 国外做化工网站实验一html静态网站开发
  • 北京中心网站建设网站建设属于什么税种
  • 静态网站建设实训报告网站可信认证必须做吗
  • react做前台网站延安软件开发公司
  • com网站怎么注册响应式网站建设费用
  • 制作好青岛百度seo
  • 建设网站学什么时候开始wordpress菜单跳出
  • wordpress中visitor网站优化具体是怎么做的
  • 做健康类网站怎么备案网站建设图片编辑
  • django做的网站举例电商网站布局设计
  • 克拉玛依市住房和建设局网站网站开发招聘年薪
  • 浙江省住房和城乡建设厅网站 文件制作表格的软件
  • 山西城乡建设厅网站wordpress的html代码
  • php的网站有哪些北京企业网站建设价格
  • 谷歌 网站开发seo搜索优化工程师招聘
  • 丰田车营销网站建设的纲要计划书做网站开封
  • 企业网站项目报价多少合适网站建设管理工作的总结
  • 网站建设山东聚搜网络一xdw2019怎么做网站
  • 建设公司官方网站做soho要不要注册网站
  • 网站分为哪些部分组成部分网站html有趣代码
  • 网站获取访客企业宣传制作app哪个好
  • 怎么建立自己的企业网站做前端网站用什么工具
  • 云浮市建设局网站sketch做网站