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

使用C#的异步和依赖注入实现网络数据存储

详细解释

  1. 依赖注入(Dependency Injection):

    • ConfigureServices 方法配置了服务的依赖注入。IDataProcessor 接口与 DataProcessor 类绑定,IDbConnectionFactory 接口与 DbConnectionFactory 类绑定。这样在程序运行时,依赖注入容器会提供这些接口的实现。
  2. 主程序入口(Main 方法):

    • 在 Main 方法中,配置服务,创建服务提供者,并通过服务提供者获取 IDataProcessor 的实现实例来处理数据。
  3. 数据处理接口(IDataProcessorDataProcessor 类):

    • IDataProcessor 是一个接口,定义了 ProcessDataAsync 方法,用于处理数据。
    • DataProcessor 类实现了 IDataProcessor 接口,负责从 API 获取数据、处理数据、保存数据到数据库并写入文件。
  4. 异步编程(asyncawait:

    • 异步编程用于避免阻塞主线程。FetchDataAsync 方法从 API 获取数据,SaveDataToDatabaseAsync 方法将数据异步保存到数据库。
  5. 数据处理(ProcessData 方法):

    • 数据处理的逻辑将每个数据项的名称转换为大写,并计算值的长度。
  6. 文件操作(WriteDataToFile 方法):

    • 将处理后的数据写入到 output.txt 文件中,每行包含 ID、名称和长度。
  7. SQLite 数据库操作:

    • 使用 System.Data.SQLite 进行数据库连接和操作。DbConnectionFactory 类提供了创建数据库连接的方法,SaveDataToDatabaseAsync 方法将处理后的数据存储到 SQLite 数据库中的 ProcessedData 表。
  8. 错误处理:

    • 使用 try-catch 块来捕捉并处理可能的异常,并输出错误信息。
using Microsoft.Extensions.DependencyInjection; // 引入依赖注入的命名空间
using Newtonsoft.Json; // 引入 JSON 处理的命名空间
using System; // 引入基本的系统功能
using System.Collections.Generic; // 引入泛型集合功能
using System.Data.SQLite; // 引入 SQLite 数据库操作的命名空间
using System.IO; // 引入文件操作的命名空间
using System.Net.Http; // 引入 HTTP 网络请求的命名空间
using System.Threading.Tasks; // 引入异步编程的命名空间namespace ComplexConsoleApp
{class Program{static async Task Main(string[] args){// 配置服务var services = new ServiceCollection();ConfigureServices(services);var serviceProvider = services.BuildServiceProvider();// 获取 IDataProcessor 实现类的实例并处理数据var dataProcessor = serviceProvider.GetService<IDataProcessor>();await dataProcessor.ProcessDataAsync();}private static void ConfigureServices(IServiceCollection services){// 将 DataProcessor 注册为 IDataProcessor 的实现services.AddTransient<IDataProcessor, DataProcessor>();// 将 DbConnectionFactory 注册为 IDbConnectionFactory 的实现services.AddSingleton<IDbConnectionFactory, DbConnectionFactory>();}}// 数据处理接口public interface IDataProcessor{Task ProcessDataAsync(); // 异步处理数据}public class DataProcessor : IDataProcessor{private readonly IDbConnectionFactory _dbConnectionFactory;private const string ApiUrl = "https://api.example.com/data"; // API 数据的 URLpublic DataProcessor(IDbConnectionFactory dbConnectionFactory){_dbConnectionFactory = dbConnectionFactory;}public async Task ProcessDataAsync(){try{// 获取数据var data = await FetchDataAsync();// 处理数据var processedData = ProcessData(data);// 将数据保存到数据库await SaveDataToDatabaseAsync(processedData);// 将数据写入文件WriteDataToFile(processedData);}catch (Exception ex){// 捕捉并输出异常信息Console.WriteLine($"发生错误: {ex.Message}");}}private async Task<List<DataItem>> FetchDataAsync(){using (var client = new HttpClient()){// 发送 HTTP GET 请求并获取响应内容var response = await client.GetStringAsync(ApiUrl);// 将 JSON 响应内容转换为 DataItem 对象的列表return JsonConvert.DeserializeObject<List<DataItem>>(response);}}private List<ProcessedDataItem> ProcessData(List<DataItem> data){// 模拟数据处理var processedData = new List<ProcessedDataItem>();foreach (var item in data){// 将每个数据项的名称转换为大写,并计算值的长度processedData.Add(new ProcessedDataItem{Id = item.Id,Name = item.Name.ToUpper(),Value = item.Value.Length});}return processedData;}private async Task SaveDataToDatabaseAsync(List<ProcessedDataItem> data){using (var connection = _dbConnectionFactory.CreateConnection()){await connection.OpenAsync(); // 打开数据库连接var transaction = connection.BeginTransaction(); // 开始事务foreach (var item in data){// 创建 SQL 命令var command = connection.CreateCommand();command.Transaction = transaction;command.CommandText = "INSERT INTO ProcessedData (Id, Name, Value) VALUES (@Id, @Name, @Value)";command.Parameters.AddWithValue("@Id", item.Id);command.Parameters.AddWithValue("@Name", item.Name);command.Parameters.AddWithValue("@Value", item.Value);await command.ExecuteNonQueryAsync(); // 执行 SQL 命令}transaction.Commit(); // 提交事务}}private void WriteDataToFile(List<ProcessedDataItem> data){using (var writer = new StreamWriter("output.txt")){foreach (var item in data){// 将处理后的数据写入文件writer.WriteLine($"{item.Id}, {item.Name}, {item.Value}");}}}}// 数据库连接工厂接口public interface IDbConnectionFactory{SQLiteConnection CreateConnection(); // 创建 SQLite 连接}public class DbConnectionFactory : IDbConnectionFactory{private const string ConnectionString = "Data Source=database.db;Version=3;"; // 数据库连接字符串public SQLiteConnection CreateConnection(){return new SQLiteConnection(ConnectionString); // 创建并返回 SQLite 连接}}// 从 API 获取的原始数据项public class DataItem{public int Id { get; set; } // 数据项的 IDpublic string Name { get; set; } // 数据项的名称public string Value { get; set; } // 数据项的值}// 处理后的数据项public class ProcessedDataItem{public int Id { get; set; } // 数据项的 IDpublic string Name { get; set; } // 数据项的名称(转换为大写)public int Value { get; set; } // 数据项的值的长度}
}

相关文章:

使用C#的异步和依赖注入实现网络数据存储

详细解释 依赖注入&#xff08;Dependency Injection&#xff09;: ConfigureServices 方法配置了服务的依赖注入。IDataProcessor 接口与 DataProcessor 类绑定&#xff0c;IDbConnectionFactory 接口与 DbConnectionFactory 类绑定。这样在程序运行时&#xff0c;依赖注入容器…...

tomcat日志文件切割

文章目录 引言I 使用用crontab工具,定时执行任务II 通过Linux系统自带的切割工具logrotate来进行切割logrotate 简介用法结合crontab进行自定义的定时轮转操作III 基于其他日志框架进行分隔引言 tomcat 的 catalina.out 文件不会进行日志切割,当这个文件大于2G 时,会影响to…...

Python将Word文档转为PDF

使用python将word转pdf_py work转pdf-CSDN博客 掌握Python技巧&#xff1a;PDF文件的加密和水印处理-CSDN博客...

深入浅出链表

目录 1.链表的基本概念及结构 1.1基本概念 1.2结构 2.链表的分类 3.链表的实现&#xff08;循环链表增删查改实现&#xff09; 1.动态申请节点&#xff08;结点&#xff09;​编辑 2.单链表打印 3.单链表尾插 4.单链表头插 5.单链表尾删 6.单链表头删 7.单链表查找 …...

Linux核心命令入门

Linux常用命令 文件管理文件目录管理文件查看编辑 系统管理网络管理hostnamehost/nslookuptraceroutenetstat列出所有端口 (包括监听和未监听的)列出所有处于监听状态的 Sockets显示每个协议的统计信息 硬件管理df&#xff08;Disk Free&#xff09;du&#xff08;Disk Usage&a…...

腾讯无界微前端框架介绍

一、无界微前端框架概述 无界微前端框架是由腾讯团队推出的&#xff0c;旨在解决现有微前端方案中存在的问题&#xff0c;如适配成本高、样式隔离困难、运行性能不佳、页面白屏、子应用通信复杂、子应用保活机制缺乏等。 技术实现 无界微前端的核心技术是基于Web Component…...

Linux——网络(2)

一、通信 --- 不同主机上进程间的通信 1、IP和端口号 IP&#xff1a;标识网络中的一台主机 本质上 32位的整型数据 端口号: 标识某个进程 本质上 16位的整型数据 2、udp和tcp udp的特点: 1.无连接 2.不可靠 tcp的特点&#xff1a; 1.面…...

结合量子技术解决数据传输安全

初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github&#xff1a;codetoys&#xff0c;所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的&#xff0c;可以在任何平台上使用。 接前篇&#xff1a;数采网关面…...

【Rust光年纪】提高开发效率:深入了解Rust语言中的数据库客户端和文件处理库

深入探索&#xff1a;Rust语言中多款数据库客户端与文件处理库详解 前言 在现代软件开发中&#xff0c;使用各种数据库和文件处理操作是非常常见的。Rust语言作为一种快速、安全、并发的系统编程语言&#xff0c;也拥有丰富的生态系统和库。本文将介绍几个用于Rust语言的数据…...

【自动驾驶】控制算法(一)绪论与前期准备

写在前面&#xff1a; &#x1f31f; 欢迎光临 清流君 的博客小天地&#xff0c;这里是我分享技术与心得的温馨角落。&#x1f4dd; 个人主页&#xff1a;清流君_CSDN博客&#xff0c;期待与您一同探索 移动机器人 领域的无限可能。 &#x1f50d; 本文系 清流君 原创之作&…...

CSDN创作一周年总结

一周年总结 文章目录 一周年总结我的第一篇文章这一年我收获到了什么&#xff1f;1.培养了逻辑能力2.形成了自己的知识库&#xff0c;知识网络3.功利性的收获 我的第一篇文章 不知不觉之间&#xff0c;也已经过去一年了。还记得第一次决定在csdn上写博客&#xff0c;是因为进入…...

World of Warcraft [CLASSIC] the Eye of Eternity [EOE] P1-P2

World of Warcraft [CLASSIC] the Eye of Eternity [EOE] 永恒之眼&#xff08;蓝龙&#xff09; 第一阶段 第二阶段 第三阶段 载具1-6技能介绍 World of Warcraft [CLASSIC] the Eye of Eternity [EOE]_永恒之眼 eoe-CSDN博客 永恒之眼怎么出副本呢&#xff0c;战斗结束&am…...

一键翻译全球:多语言支持下的英文翻译工具

随着科技的飞速发展&#xff0c;一系列英文翻译工具应运而生&#xff0c;它们以人工智能为驱动&#xff0c;极大地简化了跨语言交流的过程。本文将带您一窥英文翻译工具探索那些能够帮助我们跨越语言鸿沟的神奇工具。 1.福昕在线翻译 链接直达>>https://fanyi.pdf365.c…...

水战再起波澜,“怡宝”要下好怎样一盘棋?

不少投资者常把那些刚需性强、永远也不可能淘汰的产业称为“日不落产业”&#xff0c;从细分板块来看&#xff0c;水无疑具有一定代表性。农夫山泉掌门人钟晱晱曾直言&#xff1a;“我选择了一个日不落的产业&#xff0c;你永远要喝水&#xff0c;不可能不喝水。” 多年下来&a…...

使用maven快速生成打包文件3

这里再介绍一种打包方式&#xff0c;依赖包分开打包&#xff0c;直接将需要部署的文件打包成一个要锁文件&#xff0c;比如kafka-roma-bin.tar.gz&#xff0c;这里需要两个文件&#xff0c;一个pom2.xml&#xff0c;一个package.xml。 pom2.xml <?xml version"1.0&q…...

Excel技巧(一)

快捷键技巧 原文链接 选取某一行的数据直到最后一行&#xff1a;【CTRL SHIFT ↓ 】或者选取一行后按住SHIFT键&#xff0c;双击下边线就可以快速选取区域。 如果表格中有多行空行&#xff0c;可以先按CTRL SHIFT END&#xff0c;再按CTRL SHIFT 上下键调整&#xff0c;…...

C语言:文件复制

文本文件复制&#xff1a; #include<stdio.h>int main() {FILE* pFile1 NULL;FILE* pFile2 NULL;fopen_s(&pFile1,"D:\\11111.txt","r");fopen_s(&pFile2,"D:\\222.txt", "w");char c;while((cfgetc(pFile1))!EOF){f…...

谈谈建筑项目管理:类型、流程和工具

无论是在材料采购还是供应商管理方面&#xff0c;确保建筑项目按计划进行并控制在预算内始终是一项挑战。 如今&#xff0c;建筑项目管理正逐步采用软件驱动的方法来提升其效率。这一转型显著优化了项目规划、调度和资源配置&#xff0c;使建筑管理更加精确和高效。 什么是建…...

【Vue】生命周期函数

系列文章目录 第五章 生命周期函数 文章目录 系列文章目录 生命周期函数代表的是Vue实例&#xff0c;或者是Vue组件&#xff0c;在网页中各个生命阶段所执行的函数。生命周期函数可以分为创建阶段、挂载阶段、更新阶段以及卸载阶段。 创建阶段&#xff1a;setup挂载阶段&…...

C++系列-文件操作

文件操作 文件类型文本文件二进制文件 文件操作的三大类文件的打开方式ios::app(append)和 ios::ate(at end) 写文件写文件文件步骤读文件文件步骤二进制文件读写写一般数据写特殊数据 程序运行时产生的数据都属于临时数据&#xff0c;一旦程序运行完毕&#xff0c;就会释放&am…...

深入浅出Asp.Net Core MVC应用开发系列-AspNetCore中的日志记录

ASP.NET Core 是一个跨平台的开源框架&#xff0c;用于在 Windows、macOS 或 Linux 上生成基于云的新式 Web 应用。 ASP.NET Core 中的日志记录 .NET 通过 ILogger API 支持高性能结构化日志记录&#xff0c;以帮助监视应用程序行为和诊断问题。 可以通过配置不同的记录提供程…...

智能在线客服平台:数字化时代企业连接用户的 AI 中枢

随着互联网技术的飞速发展&#xff0c;消费者期望能够随时随地与企业进行交流。在线客服平台作为连接企业与客户的重要桥梁&#xff0c;不仅优化了客户体验&#xff0c;还提升了企业的服务效率和市场竞争力。本文将探讨在线客服平台的重要性、技术进展、实际应用&#xff0c;并…...

k8s业务程序联调工具-KtConnect

概述 原理 工具作用是建立了一个从本地到集群的单向VPN&#xff0c;根据VPN原理&#xff0c;打通两个内网必然需要借助一个公共中继节点&#xff0c;ktconnect工具巧妙的利用k8s原生的portforward能力&#xff0c;简化了建立连接的过程&#xff0c;apiserver间接起到了中继节…...

JVM 内存结构 详解

内存结构 运行时数据区&#xff1a; Java虚拟机在运行Java程序过程中管理的内存区域。 程序计数器&#xff1a; ​ 线程私有&#xff0c;程序控制流的指示器&#xff0c;分支、循环、跳转、异常处理、线程恢复等基础功能都依赖这个计数器完成。 ​ 每个线程都有一个程序计数…...

MySQL 知识小结(一)

一、my.cnf配置详解 我们知道安装MySQL有两种方式来安装咱们的MySQL数据库&#xff0c;分别是二进制安装编译数据库或者使用三方yum来进行安装,第三方yum的安装相对于二进制压缩包的安装更快捷&#xff0c;但是文件存放起来数据比较冗余&#xff0c;用二进制能够更好管理咱们M…...

逻辑回归暴力训练预测金融欺诈

简述 「使用逻辑回归暴力预测金融欺诈&#xff0c;并不断增加特征维度持续测试」的做法&#xff0c;体现了一种逐步建模与迭代验证的实验思路&#xff0c;在金融欺诈检测中非常有价值&#xff0c;本文作为一篇回顾性记录了早年间公司给某行做反欺诈预测用到的技术和思路。百度…...

Python竞赛环境搭建全攻略

Python环境搭建竞赛技术文章大纲 竞赛背景与意义 竞赛的目的与价值Python在竞赛中的应用场景环境搭建对竞赛效率的影响 竞赛环境需求分析 常见竞赛类型&#xff08;算法、数据分析、机器学习等&#xff09;不同竞赛对Python版本及库的要求硬件与操作系统的兼容性问题 Pyth…...

面试高频问题

文章目录 &#x1f680; 消息队列核心技术揭秘&#xff1a;从入门到秒杀面试官1️⃣ Kafka为何能"吞云吐雾"&#xff1f;性能背后的秘密1.1 顺序写入与零拷贝&#xff1a;性能的双引擎1.2 分区并行&#xff1a;数据的"八车道高速公路"1.3 页缓存与批量处理…...

【HarmonyOS 5】鸿蒙中Stage模型与FA模型详解

一、前言 在HarmonyOS 5的应用开发模型中&#xff0c;featureAbility是旧版FA模型&#xff08;Feature Ability&#xff09;的用法&#xff0c;Stage模型已采用全新的应用架构&#xff0c;推荐使用组件化的上下文获取方式&#xff0c;而非依赖featureAbility。 FA大概是API7之…...

DeepSeek越强,Kimi越慌?

被DeepSeek吊打的Kimi&#xff0c;还有多少人在用&#xff1f; 去年&#xff0c;月之暗面创始人杨植麟别提有多风光了。90后清华学霸&#xff0c;国产大模型六小虎之一&#xff0c;手握十几亿美金的融资。旗下的AI助手Kimi烧钱如流水&#xff0c;单月光是投流就花费2个亿。 疯…...