- RabbitMQ的事务机制
一只小小攻城狮
RabbitMQrabbitmq分布式
想要保证发送者一定能把消息发送给RabbitMQ,一种是通过Confirm机制,另一种就是通过事务机制。RabbitMQ的事务机制,允许生产者将一组操作打包成一个原子事务单元,要么全部执行成功,要么全部失败。事务提供了一种确保消息完整性的方法,但需要谨慎使用,因为他们对性能有一定的影响。RabbitMQ是基于AMQP协议实现的,RabbitMQ中,事务是通过在通道(Channel)上启用的,与事务
- 【5G NR 协议解读】3GPP TS 38.212 (R18) 复用和信道编码(一)
瑶光守护者
5G
前言本文基于3GPPTS38.212(R18)复用和信道编码协议。本文档规定了5GNR的编码、多路复用和物理信道映射。4映射到物理信道4.1上行链路表4.1-1规定了上行传输信道到其对应物理信道的映射。表4.1-2规定了上行控制信道信息到其对应物理信道的映射。Table4.1-1TrCHPhysicalChannelUL-SCHPUSCHRACHPRACHTable4.1-2Controlinfo
- Redis-发布与订阅
凌睿马
Redisredis数据库缓存
Redis的发布与订阅功能可以让客户端通过广播方式,将消息(message)同时发送给可能存在的多个客户端,并且发送消息的客户端不需要知道接收消息的客户端的具体信息。换句话说,发布消息的客户端与接收消息的客户端两者之间没有直接联系。1PUBLISH:向频道发送消息用户可以通过执行PUBLISH命令,将一条消息发送至给定频道:PUBLISHchannelmessage2SUBSCRIBE:订阅频道用
- 2024-3-17Go语言入门
weixin_51187533
golang开发语言后端
在Go语言中:varachanint定义了一个名为a的变量,其类型为chanint。这意味着a是一个整型值的通道(channel)。通道是Go语言中用于goroutine之间通信的一种机制,你可以通过通道发送和接收特定类型的值。在这个例子中,通道允许传递整型数值。varafunc(string)int定义了一个名为a的变量,其类型为函数类型,具体来说是一个接受一个字符串作为参数并返回一个整数的函数
- Redis 订阅发布(Pub/Sub) 详解 如何使用订阅发布
交集是空集
redis缓存运维数据库
Pub/Sub(发布订阅)Redis的发布订阅(Pub/Sub)是一种消息传递模式,它允许消息的发送者(发布者)将消息发送到通道,而订阅者则可以订阅一个或多个通道,并接收发布者发送到这些通道的消息。发布订阅模式在实时通信和消息传递系统中非常有用,它可以用于构建聊天应用、实时数据更新、事件通知等场景。以下是Redis发布订阅功能的主要特点和用法:通道(Channel):发布订阅模式通过通道进行消息传
- Vue<动态修改浏览器头部小图标及标题>
誰在花里胡哨
修改位置:此处是如何动态修改的,如果你想要简单的配置图标的话,点击查看可以此篇文章image.png在index.html里面进行配置(.ico为你要动态更换的图标)image.png代码如下:-->-->-->//此处是通过判断session里面存储的渠道CHANNEL进行判断varchannel=window.sessionStorage.CHANNELvarhead=document.get
- android 事件分发笔记
呆咖啡
事件分发androidviewview事件处理
这是学习笔记,以我看得明白为主。分为view.dispatchTouchEvent,---只有事件的处理逻辑-----ViewGroup.dispatchTouchEvent---实现了分发流程的逻辑事件接收流程setView#ViewRootImpl.java//接收事件的方法------>newWindowInputEventReceiver(inputChannel,Looper.myLoo
- flume集成kafka
weixin_34112181
大数据pythonjava
2019独角兽企业重金招聘Python工程师标准>>>1.kafka的配置参照https://my.oschina.net/u/1591525/blog/22519102.flum配置在flume的conf目录下新建kafka.propertiesagent.sources=s1agent.channels=c1agent.sinks=k1agent.sources.s1.type=execage
- Netty架构详解
思静语
Netty网络通信
文章目录概述整体结构Netty的核心组件逻辑架构BootStrap&ServerBootStrapChannelPipelineFuture、回调和ChannelHandler选择器、事件和EventLoopChannelHandler的各种ChannelInitializer类图ProtocolSupport协议支持层TransportService传输服务层Core核心层模块netty-com
- mutex 和 channel 哪一个工作效率更高?
许野平
rust#Rustrustmutexchannel效率
关于Rust中mutex和channel哪一个工作效率更高的问题,实际上并没有一个绝对的答案,因为效率的高低取决于具体的使用场景和需求。互斥锁(mutex)主要用于保护共享资源,确保一次只有一个线程可以访问它。当需要多个线程同时修改共享数据,并且这些修改操作需要保持原子性和一致性时,mutex是非常合适的。它的优点在于代码简单,适用于低时间开销的场景,如并发写map等。然而,使用mutex可能会导
- 不同框架表示图像时维度顺序的区别:pytorch、keras&tf、opencv、numpy、PIL
蓝海渔夫
pythonpytorchpytorchkerasopencvpillowpython人工智能numpy
在PyTorch、Keras、OpenCV、NumPy和PIL这几个框架中,它们在表示图像时的维度存储顺序有所不同。下面我将逐一解释每个框架中图像维度的存储顺序:1,PyTorch:PyTorch中图像的维度顺序通常遵循[N,C,H,W]的格式,也就是channelfirst格式,其中:C代表通道数(channels),例如RGB图像有3个通道。N代表批量大小(batchsize),即一次处理的图
- GO基础记录
@新法
GOgolang开发语言后端
defer:生命周期结束后执行(栈顺序),在打开一些资源后,可以使用defer执行关闭.释放的操作,类似RAIIpanic:类似于throw,抛出异常make()用于构建切片,map,channeldefer,panic,recover配合使用代码deferfunc(){ifret:=recover();ret!=nil{fmt.print(ret)}}panic("error")interfac
- 【React架构 - Scheduler中的MessageChannel】
weixin_44273311
react.js架构javascript
前序我们都知道JS代码是在浏览器5个进程(下面有介绍)中渲染进程中的Js引擎线程执行的,其他还有GUI渲染线程、定时器线程等,而页面的布局和绘制是在GUI线程中完成的,这些线程之间是互斥的,所以在执行Js的同时会阻塞页面的渲染绘制。60帧我们是认识标准帧率,所以我们本文都是以60帧来进行说明,即16ms。所以我们需要在16ms之内完成Js解析执行、样式布局、页面绘制这三个步骤,如果Js执行太长时间
- golang学习笔记——Context 并发编程简明教程
怪我冷i
golang从入门到入门golang学习笔记
文章目录1为什么需要Context2context.WithCancel2.1控制单个协程2.2控制多个协程3context.WithValue4context.WithTimeout5context.WithDeadline1为什么需要ContextWaitGroup和信道(channel)是常见的2种并发控制的方式。如果并发启动了多个子协程,需要等待所有的子协程完成任务,WaitGroup非常
- 03OpenCV图像的掩膜操作
吃个糖糖
OpenCVc++opencv
文章目录掩膜操作提高图像的对比度获取图像像素制作图像掩膜算子防止像素溢出算子全部代码掩膜操作提高图像的对比度红色是中心像素,从上到下,从左到右对每个像素做同样的处理操作,得到最终结果就是对比度提高之后的输出图像Mat对象注:相当于用一个刷子把图像的每隔几点的颜色增强(理解就行),以下为代码表达intcols=(src.cols-1)*src.channels();//src.cols为图像的列in
- Chapter 8 - 18. Congestion Management in TCP Storage Networks
mounter625
Linuxkernel网络web安全安全linuxkernel
ComparisonwithLosslessNetworksRecallthatinFibreChannelfabrics(explainedinChapter3,“DetectingCongestioninFibreChannelFabrics”)andlosslessEthernetnetworks(explainedinChapter7),whenthesourceofcongestioni
- 【架构】SRAM的安全性
Xinyao Zheng
架构
Low-CostSide-ChannelSecureStandard6T-SRAM-BasedMemoryWitha1%AreaandLessThan5%LatencyandPowerOverheads侧信道分析(SCA)攻击是对加密设备的强大威胁,因为它们利用了与其物理行为相关的内部敏感信息[1],[2]。低级缓存(例如嵌入式存储器)在许多VLSI片上系统(SoC)[13]的面积和功耗中占主导地
- netty的TCP服务端和客户端实现
nanshaws
tcp/ipudp网络netty后端服务器
第一步:引入依赖io.nettynetty-all4.1.90.Final第二步:实现TCP服务端packageorg.cyl.tcputils;importio.netty.bootstrap.ServerBootstrap;importio.netty.channel.ChannelFuture;importio.netty.channel.ChannelInitializer;importi
- 【Go channel如何控制goroutine并发执行顺序?】
GOLANG ROADMAP
golang
多个goroutine并发执行时,每一个goroutine抢到处理器的时间点不一致,gorouine的执行本身不能保证顺序。即代码中先写的gorouine并不能保证先执行思路:使用channel进行通信通知,用channel去传递信息,从而控制并发执行顺序packagemainimport("fmt""sync""time")varwgsync.WaitGroupfuncmain(){ch1:=m
- 本地模拟发送、接收RabbitMQ数据
tag心动
rabbitmq分布式mq模拟发送接收消息rabbitmq模拟测试
文章目录前言一、相关文章二、相关代码1.模拟的Channel类2.接收消息3.模拟推送MQ数据前言日常开发中,当线上RabbitMQ坏境还没准备好时,可在本地模拟发送、接收消息一、相关文章Docker安装RabbitMQ【SpringCloud】整合RabbitMQ六大模式应用(入门到精通)SpringRabbitMQ配置多个虚拟主机(vhost)二、相关代码
- Flutter App Run卡在Running Gradle task 'assembleDebug'...
JerrySmurfs
Flutterandroidstudioflutter
配置Flutter开发环境,根据网上的教程安装IDE,SDK、各种插件和依赖包手机:VIVOX21UDA开发工具:AndroidStudio3.6.2Flutter:1.17.0channelbetaJavaJDK:1.8.0_202gradle:gradle-6.3新建了一个Flutter工程后,Run卡在了RunningGradletask‘assembleDebug’…百度查询原因是因为Gr
- 【C/C++】实现Reactor高并发服务器 完整版
橙留香写代码
服务器c语言c++
代码结构文件介绍InetAddress.hInetAddress类ip和端口设置Socket.hSocket类设置fdEpoll.hepollfd管理类Channel.hChannel类管理epoll以及对应回调函数实现EventLoop.hEventLoop事件循环类TcpServer.h服务器类tcpepoll.cpp主函数InetAddress.h#ifndef_INETADDRESS_H#
- Bibox发布全球首个通证债券
JoXt6FWu
北京时间11月22日,全球排名前10的Al数字资产交易平台Bibox发布全球首个通证债券Biboxbond一基于Bibox平台通证发行的债券合约,其发行价值挂钩稳定币GUSD,成熟期为6个月。此次Bibox发行债券,不仅完善了市场结构,满足市场对低风险、稳定收益的需求,为专业的投资者提供了风险对冲和资产配置的方式,而且也填补了数字资产领域债券融资的空白。据Bibox联合创始人AriesWang介绍
- Unreadable-Mesh内存占用翻倍问题
1)Unreadable-Mesh内存占用翻倍问题2)在TMP中计算书名号《》高度的问题3)Mipmap如何限定层级4)FMOD设置中关于VirtualChannelCount&RealChannelCount的参数疑问这是第374篇UWA技术知识分享的推送,精选了UWA社区的热门话题,涵盖了UWA问答、社区帖子等技术知识点,助力大家更全面地掌握和学习。UWA社区主页:community.uwa4
- 从零开始学习Netty - 学习笔记 - NIO基础 - ByteBuffer: 简介和基本操作
花开十里落叶无情
nettynettynioByteBuffer
NIO基础1.三大组件1.1.Channel&BufferChannel在JavaNIO(NewI/O)中,“Channel”(通道)是一个重要的概念,用于在非阻塞I/O操作中进行数据的传输。JavaNIO提供了一种更为灵活和高效的I/O处理方式,相比于传统的I/O,它具有更好的性能和可扩展性。常见的JavaNIO中的通道类型:FileChannel(文件通道):用于文件I/O操作的通道,可以在文
- Flutter插件开发指南02: 事件订阅 EventChannel
flutter
Flutter插件开发指南02:事件订阅EventChannel视频https://www.bilibili.com/video/BV1zj411d7k4/前言上一节我们讲了Channel通道,但是如果你是卫星定位业务,原生端主动推消息给Flutter这时候就要用到EventChannel通道了。本节会写一个1~50的计数器,到50后自动关闭原生的消息订阅。FlutterEventChannelF
- Flutter插件开发指南02: 事件订阅 EventChannel
flutter
Flutter插件开发指南02:事件订阅EventChannel视频https://www.bilibili.com/video/BV1zj411d7k4/前言上一节我们讲了Channel通道,但是如果你是卫星定位业务,原生端主动推消息给Flutter这时候就要用到EventChannel通道了。本节会写一个1~50的计数器,到50后自动关闭原生的消息订阅。FlutterEventChannelF
- Flutter插件开发指南01: 通道Channel的编写与实现
flutter
Flutter插件开发指南01:通道Channel的编写与实现视频https://www.bilibili.com/video/BV1ih4y1E7E3/前言本文将会通过一个加法计算,来实现Channel的双向通讯,让大家有个一个体会。Flutter插件Flutter插件是Flutter应用程序与原生平台之间的桥梁,使得Flutter应用程序可以与原生代码进行交互,从而扩展Flutter应用程序的
- 「连载」边缘计算(十五)02-18:边缘部分源码(源码分析篇)
十越科技
边缘计算人工智能
(接上篇)ChannelContextstruct定义如下所示。KubeEdge/beehive/pkg/core/context/context.go//ChannelContextisobjectforContextchanneltypeChannelContextstruct{//ConfigFactorygoarchaius.ConfigurationFactorychannelsmap[
- Redis(03)——发布订阅
爱编程的小生
Redisredis数据库缓存
基础命令基于频道publishchannelmessage:将信号发送到指定的频道pubsubsubcommand[argument[argyment]]:查看订阅或发布系统状态subscribechannel[channel]:订阅一个或多个频道的信息unsubscribe[channel[channel]]:退订指定的频道,若没有指定频道,则默认退订所有频道基于模式psubcribepatte
- java线程Thread和Runnable区别和联系
zx_code
javajvmthread多线程Runnable
我们都晓得java实现线程2种方式,一个是继承Thread,另一个是实现Runnable。
模拟窗口买票,第一例子继承thread,代码如下
package thread;
public class ThreadTest {
public static void main(String[] args) {
Thread1 t1 = new Thread1(
- 【转】JSON与XML的区别比较
丁_新
jsonxml
1.定义介绍
(1).XML定义
扩展标记语言 (Extensible Markup Language, XML) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言。 XML使用DTD(document type definition)文档类型定义来组织数据;格式统一,跨平台和语言,早已成为业界公认的标准。
XML是标
- c++ 实现五种基础的排序算法
CrazyMizzz
C++c算法
#include<iostream>
using namespace std;
//辅助函数,交换两数之值
template<class T>
void mySwap(T &x, T &y){
T temp = x;
x = y;
y = temp;
}
const int size = 10;
//一、用直接插入排
- 我的软件
麦田的设计者
我的软件音乐类娱乐放松
这是我写的一款app软件,耗时三个月,是一个根据央视节目开门大吉改变的,提供音调,猜歌曲名。1、手机拥有者在android手机市场下载本APP,同意权限,安装到手机上。2、游客初次进入时会有引导页面提醒用户注册。(同时软件自动播放背景音乐)。3、用户登录到主页后,会有五个模块。a、点击不胫而走,用户得到开门大吉首页部分新闻,点击进入有新闻详情。b、
- linux awk命令详解
被触发
linux awk
awk是行处理器: 相比较屏幕处理的优点,在处理庞大文件时不会出现内存溢出或是处理缓慢的问题,通常用来格式化文本信息
awk处理过程: 依次对每一行进行处理,然后输出
awk命令形式:
awk [-F|-f|-v] ‘BEGIN{} //{command1; command2} END{}’ file
[-F|-f|-v]大参数,-F指定分隔符,-f调用脚本,-v定义变量 var=val
- 各种语言比较
_wy_
编程语言
Java Ruby PHP 擅长领域
- oracle 中数据类型为clob的编辑
知了ing
oracle clob
public void updateKpiStatus(String kpiStatus,String taskId){
Connection dbc=null;
Statement stmt=null;
PreparedStatement ps=null;
try {
dbc = new DBConn().getNewConnection();
//stmt = db
- 分布式服务框架 Zookeeper -- 管理分布式环境中的数据
矮蛋蛋
zookeeper
原文地址:
http://www.ibm.com/developerworks/cn/opensource/os-cn-zookeeper/
安装和配置详解
本文介绍的 Zookeeper 是以 3.2.2 这个稳定版本为基础,最新的版本可以通过官网 http://hadoop.apache.org/zookeeper/来获取,Zookeeper 的安装非常简单,下面将从单机模式和集群模式两
- tomcat数据源
alafqq
tomcat
数据库
JNDI(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API。
没有使用JNDI时我用要这样连接数据库:
03. Class.forName("com.mysql.jdbc.Driver");
04. conn
- 遍历的方法
百合不是茶
遍历
遍历
在java的泛
- linux查看硬件信息的命令
bijian1013
linux
linux查看硬件信息的命令
一.查看CPU:
cat /proc/cpuinfo
二.查看内存:
free
三.查看硬盘:
df
linux下查看硬件信息
1、lspci 列出所有PCI 设备;
lspci - list all PCI devices:列出机器中的PCI设备(声卡、显卡、Modem、网卡、USB、主板集成设备也能
- java常见的ClassNotFoundException
bijian1013
java
1.java.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory 添加包common-logging.jar2.java.lang.ClassNotFoundException: javax.transaction.Synchronization
- 【Gson五】日期对象的序列化和反序列化
bit1129
反序列化
对日期类型的数据进行序列化和反序列化时,需要考虑如下问题:
1. 序列化时,Date对象序列化的字符串日期格式如何
2. 反序列化时,把日期字符串序列化为Date对象,也需要考虑日期格式问题
3. Date A -> str -> Date B,A和B对象是否equals
默认序列化和反序列化
import com
- 【Spark八十六】Spark Streaming之DStream vs. InputDStream
bit1129
Stream
1. DStream的类说明文档:
/**
* A Discretized Stream (DStream), the basic abstraction in Spark Streaming, is a continuous
* sequence of RDDs (of the same type) representing a continuous st
- 通过nginx获取header信息
ronin47
nginx header
1. 提取整个的Cookies内容到一个变量,然后可以在需要时引用,比如记录到日志里面,
if ( $http_cookie ~* "(.*)$") {
set $all_cookie $1;
}
变量$all_cookie就获得了cookie的值,可以用于运算了
- java-65.输入数字n,按顺序输出从1最大的n位10进制数。比如输入3,则输出1、2、3一直到最大的3位数即999
bylijinnan
java
参考了网上的http://blog.csdn.net/peasking_dd/article/details/6342984
写了个java版的:
public class Print_1_To_NDigit {
/**
* Q65.输入数字n,按顺序输出从1最大的n位10进制数。比如输入3,则输出1、2、3一直到最大的3位数即999
* 1.使用字符串
- Netty源码学习-ReplayingDecoder
bylijinnan
javanetty
ReplayingDecoder是FrameDecoder的子类,不熟悉FrameDecoder的,可以先看看
http://bylijinnan.iteye.com/blog/1982618
API说,ReplayingDecoder简化了操作,比如:
FrameDecoder在decode时,需要判断数据是否接收完全:
public class IntegerH
- js特殊字符过滤
cngolon
js特殊字符js特殊字符过滤
1.js中用正则表达式 过滤特殊字符, 校验所有输入域是否含有特殊符号function stripscript(s) { var pattern = new RegExp("[`~!@#$^&*()=|{}':;',\\[\\].<>/?~!@#¥……&*()——|{}【】‘;:”“'。,、?]"
- hibernate使用sql查询
ctrain
Hibernate
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import org.hibernate.Hibernate;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.hibernate.Transa
- linux shell脚本中切换用户执行命令方法
daizj
linuxshell命令切换用户
经常在写shell脚本时,会碰到要以另外一个用户来执行相关命令,其方法简单记下:
1、执行单个命令:su - user -c "command"
如:下面命令是以test用户在/data目录下创建test123目录
[root@slave19 /data]# su - test -c "mkdir /data/test123" 
- 好的代码里只要一个 return 语句
dcj3sjt126com
return
别再这样写了:public boolean foo() { if (true) { return true; } else { return false;
- Android动画效果学习
dcj3sjt126com
android
1、透明动画效果
方法一:代码实现
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
{
View rootView = inflater.inflate(R.layout.fragment_main, container, fals
- linux复习笔记之bash shell (4)管道命令
eksliang
linux管道命令汇总linux管道命令linux常用管道命令
转载请出自出处:
http://eksliang.iteye.com/blog/2105461
bash命令执行的完毕以后,通常这个命令都会有返回结果,怎么对这个返回的结果做一些操作呢?那就得用管道命令‘|’。
上面那段话,简单说了下管道命令的作用,那什么事管道命令呢?
答:非常的经典的一句话,记住了,何为管
- Android系统中自定义按键的短按、双击、长按事件
gqdy365
android
在项目中碰到这样的问题:
由于系统中的按键在底层做了重新定义或者新增了按键,此时需要在APP层对按键事件(keyevent)做分解处理,模拟Android系统做法,把keyevent分解成:
1、单击事件:就是普通key的单击;
2、双击事件:500ms内同一按键单击两次;
3、长按事件:同一按键长按超过1000ms(系统中长按事件为500ms);
4、组合按键:两个以上按键同时按住;
- asp.net获取站点根目录下子目录的名称
hvt
.netC#asp.nethovertreeWeb Forms
使用Visual Studio建立一个.aspx文件(Web Forms),例如hovertree.aspx,在页面上加入一个ListBox代码如下:
<asp:ListBox runat="server" ID="lbKeleyiFolder" />
那么在页面上显示根目录子文件夹的代码如下:
string[] m_sub
- Eclipse程序员要掌握的常用快捷键
justjavac
javaeclipse快捷键ide
判断一个人的编程水平,就看他用键盘多,还是鼠标多。用键盘一是为了输入代码(当然了,也包括注释),再有就是熟练使用快捷键。 曾有人在豆瓣评
《卓有成效的程序员》:“人有多大懒,才有多大闲”。之前我整理了一个
程序员图书列表,目的也就是通过读书,让程序员变懒。 写道 程序员作为特殊的群体,有的人可以这么懒,懒到事情都交给机器去做,而有的人又可
- c++编程随记
lx.asymmetric
C++笔记
为了字体更好看,改变了格式……
&&运算符:
#include<iostream>
using namespace std;
int main(){
int a=-1,b=4,k;
k=(++a<0)&&!(b--
- linux标准IO缓冲机制研究
音频数据
linux
一、什么是缓存I/O(Buffered I/O)缓存I/O又被称作标准I/O,大多数文件系统默认I/O操作都是缓存I/O。在Linux的缓存I/O机制中,操作系统会将I/O的数据缓存在文件系统的页缓存(page cache)中,也就是说,数据会先被拷贝到操作系统内核的缓冲区中,然后才会从操作系统内核的缓冲区拷贝到应用程序的地址空间。1.缓存I/O有以下优点:A.缓存I/O使用了操作系统内核缓冲区,
- 随想 生活
暗黑小菠萝
生活
其实账户之前就申请了,但是决定要自己更新一些东西看也是最近。从毕业到现在已经一年了。没有进步是假的,但是有多大的进步可能只有我自己知道。
毕业的时候班里12个女生,真正最后做到软件开发的只要两个包括我,PS:我不是说测试不好。当时因为考研完全放弃找工作,考研失败,我想这只是我的借口。那个时候才想到为什么大学的时候不能好好的学习技术,增强自己的实战能力,以至于后来找工作比较费劲。我
- 我认为POJO是一个错误的概念
windshome
javaPOJO编程J2EE设计
这篇内容其实没有经过太多的深思熟虑,只是个人一时的感觉。从个人风格上来讲,我倾向简单质朴的设计开发理念;从方法论上,我更加倾向自顶向下的设计;从做事情的目标上来看,我追求质量优先,更愿意使用较为保守和稳妥的理念和方法。
&