- 用Docker搭建Redis主从复制的集群
2401_84046635
程序员dockerrediseureka
同样再到redis-slave1容器的命令窗口里,通过dockerexec-itredis-slave1/bin/bash命令进入容器的命令行窗口,也通过redis-cli命令进入客户端命令行,也再通过inforeplication命令查看该Redis服务器的主从模式的状态,部分结果如下所示。1c:\work>dockerexec-itredis-slave1/bin/bash2root@2e32
- 【数据分析】4 商业数据分析技能模型总结
loyd3
数据分析数据分析数据挖掘
优秀的商业分析师需要具备的能力数据分析能力逻辑思维能力赢得结果能力一、数据分析能力扩展:工具链生态与进阶场景1.数据获取技术升级企业级数据源管理:数据湖架构(AWSS3/阿里云OSS)与数据仓库(Snowflake/Redshift)权限管理API自动化采集(Postman+PythonRequests模块)反爬虫策略突破(IP代理池/Selenium模拟登录)新兴数据源拓展:社交舆情数据(Twi
- Redis缓存预热、缓存穿透、缓存击穿、缓存雪崩
辄也
缓存redis数据库
一、缓存预热1.什么是缓存预热?当系统上线时,缓存内还没有数据,如果直接提供给用户使用,每个请求都会穿过缓存去访问底层数据库,如果并发大的话,很有可能在上线当天就会宕机,因此我们需要在上线前先将数据库内的热点数据缓存至Redis内再提供出去使用,这种操作就成为"缓存预热"。2.问题排查请求数量较高主从之间数据吞吐量较大,数据同步操作频度较高3.解决方案1.日常例行统计数据访问记录,统计访问频度较高
- avue富文本编辑器如何保证上传图片正常
R-sz
java前端javascript
{label:"内容",prop:"content",component:'AvueUeditor',action:"/api/blade-resource/oss/endpoint/put-file",propsHttp:{res:"data",url:"link",},hide:true,viewDisplay:false,minRows:6,span:24,rules:[{required:
- Java本地缓存技术选型(Guava Cache、Caffeine、EhCache)
子龙技术
java
前言对一个java开发者而言,提到缓存,第一反应就是Redis。利用这类缓存足以解决大多数的性能问题了,我们也要知道,这种属于remotecache(分布式缓存),应用的进程和缓存的进程通常分布在不同的服务器上,不同进程之间通过RPC或HTTP的方式通信。这种缓存的优点是缓存和应用服务解耦,支持大数据量的存储,缺点是数据要经过网络传输,性能上会有一定损耗。与分布式缓存对应的是本地缓存,缓存的进程和
- java将文件流传给前端,JAVA基础知识之InputStreamReader流 和 将本地文件通过前端上传到服务器上...
GrapeDoor
java将文件流传给前端
将本地文件通过前端上传到服务器上publicBaseResponseSwaggerresolveFile(@Valid@ApiParam(value="file")@RequestParam(name="file",required=true)MultipartFilefile){if(file.isEmpty()){thrownewSoftwareException(ComStatusCodeE
- win10下安装wireshark的问题
(??(#?)???(???/
wireshark测试工具网络
win10下安装wireshark的问题1.wireshark启动之后找不到本地接口问题2.安装winpcap的问题显示AnerroroccurredwhileinstallingtheNPFdiver(0x00000430).显示WinPcap4.1.3isalreadyinstalledonthismachine.PressOkifyouwanttoforcetheinstallation,o
- cv2.solvePnP 报错 求相机位姿
AI算法网奇
3d渲染python基础数码相机
目录报错信息及解决:cv2.solvePnP使用例子:报错信息及解决:File"/shared_disk/users/lbg/project/human_4d/nlf_pose/render_demo_pkl2_cal.py",line236,insuccess,rotation_vector,translation_vector=cv2.solvePnP(vertices,vertices2d,
- 【YashanDB 知识库】由于 druid 中间件配置导致异常
数据库
问题现象某客户的业务(Java框架)运行时报如下异常:问题的风险及影响客户的业务无法正常运行问题影响的版本所有的yashandb版本问题发生原因druid中间件有如下参数,可以控制是否缓存PreparedStatement,客户现场为如下配置:share-prepared-statements:truepool-prepared-statements:truemax-open-prepared-s
- C++11 智能指针:unique_ptr、shared_ptr和weak_ptr 功能特性 模拟实现
Chandler24
C++c++开发语言
文章目录unique_ptr功能和特性使用场景make_unique模拟实现shared_ptr功能和特性使用场景make_shared模拟实现weak_ptrC++中智能指针都是RAII(ResourceAcquisitionIsInitialization)机制的典型应用,在构造时获取资源,在析构时释放资源,将资源管理与对象的生命周期绑定,使得资源管理更加直观和可靠。unique_ptrstd
- linux c和windows c,windows C 与 linux C区别?
冷承志
linuxc和windowsc
windowsC库格式为.dll(动态链接库英文为DLL,是DynamicLinkLibrary的缩写形式,DLL是一个包含可由多个程序同时使用的代码和数据的库,DLL不是可执行文件)。生成的*.exe。linuxC库格式为.so(.so为共享库:动态库(sharedlibrary/sharedobject/dynamiclinklibrary)。生成*elf(LinuxELFELF=Execut
- 微信小程序页面导航与路由:实现多页面跳转与数据传递
Evaporator Core
微信小程序开发入门微信小程序notepad++小程序
在上一篇中,我们学习了微信小程序的数据绑定和事件处理,实现了动态交互功能。然而,一个完整的小程序通常由多个页面组成,用户需要在不同页面之间进行跳转。本文将深入探讨微信小程序的页面导航与路由机制,帮助你实现多页面跳转以及页面间的数据传递。一、页面导航的基本概念微信小程序的页面导航通过路由机制实现,开发者可以通过代码或组件的方式实现页面跳转。页面导航的核心是wx.navigateTo、wx.redir
- 记一次pytorch训练loss异常的问题
lyyiangang
pytorch人工智能python
记一次pytorch训练loss异常的问题问题描述使用mmdetection框架训练时,某项loss出现异常大的值,比如1781232349724294.000。这个问题只在多卡训练时才会出现。解决方法在确认target和predction没有问题后,发现是在dataset中的数据处理出现了问题。在dataset中的__getitem__函数中,对数据进行了处理,但是在处理时,将数据转换为了num
- React低代码项目:Redux 状态管理
CaptainDrake
#低代码项目react.js低代码前端
吐司问卷:Redux状态管理Date:February18,20255:37PM(GMT+8)Redux管理用户信息命名规范:以Info结尾表示获取Reudx信息,比如useGetUserInfo.ts以data结尾表示获取服务端信息,比如useLoadQuestionData采用Redux管理用户信息Reduxstore设计:src/store/index.tsimport{configureS
- 【C++】智能指针
FFFfengZiz.
c++开发语言
在C++中没有垃圾回收机制,必须自己释放分配的内存,否则就会造成内存泄露。解决这个问题最有效的方法是使用智能指针(smartpointer)。笔记借鉴了《c++11实用特性[c/c++项目开发必备技能]》课程文章目录一、shared_ptr共享智能指针1.1shared_ptr的初始化1.1.1通过构造函数初始化1.1.2通过拷贝和移动构造函数初始化1.1.3make_shared()1.1.4通
- 飘还是不飘?“`“引发的惨案。
dushky
java前端开发语言
Failedtoconvertvalueoftype'java.lang.String'torequiredtype'int';Forinputstring:"${page}"当您的后端服务报这个错误时?发生什么?乍一看,什么都没问题。后端服务正常启动,用swagger(Knife4j)测试好着呢。前端也没什么问题,该传的,都传了呀?特别是眼神不太好的,还看不出来'和`的区别。:-)注意前端传参的
- R语言装环境Gcc报错以及scater包的安装
一穷二白到年薪百万
环境配置condalinux
error:‘timespec_get’hasnotbeendeclaredin‘::’80|using::timespec_get;在conda的虚拟环境中升级gcc的版本condainstall-cconda-forgegcc=11gxx=11终极方法,在R的最新版本和环境下装啥都能成功!!比如beyondcell的方法的BeyondcellScoreNormalization中scater包
- conda创建环境/安装包报错网络问题
胖胖大王叫我来巡山
condapython
1.报错(base)xx@xxxdeMacBook-Proanaconda3%condacreate-nworkpython=3.7.11Collectingpackagemetadata(current_repodata.json):failedCondaHTTPError:HTTP000CONNECTIONFAILEDforurlElapsed:-AnHTTPerroroccurredwhen
- redission的原理
深圳卢先生
java
分布式锁的实现Redisson最出名的功能之一是分布式锁(RLock)。它的锁机制基于Redis的原子性操作:使用SETNX(SETifNoteXists)命令尝试获取锁,并设置一个过期时间(防止死锁)。通过Lua脚本确保锁的释放是原子性的,只有持有锁的客户端才能释放锁。支持锁续期(Watchdog机制):如果任务未完成,Redisson会自动为锁延长过期时间。实现细节1.锁的基本存储Rediss
- 中断、异常 、故障、陷阱与中止他妈的到底是什么
我代码抄都抄不明白
windowsvisualstudiomicrosoftc语言
interrupts:中断trap:陷阱abort:中止faults:故障exception:异常英特尔x86定义了两个重叠的类别:矢量事件vectoredevents(中断与异常)异常类exceptionclasses(故障、陷阱与中止)。向量事件vectoredevents主要作用:向量化事件(中断和异常)导致处理器在保存了处理器的大部分状态(足够让执行可以从该点继续执行)之后,跳转到中断处理
- Redis面试题----为什么要做Redis分区?
指尖下的技术
Java面试题redisjava数据库
Redis分区,也称为分片(Sharding),是将数据分散存储到多个Redis实例上的一种策略。做Redis分区主要有以下几个方面的原因:扩展性突破单机内存限制:随着业务的发展,数据量会不断增大,而单个Redis实例的内存是有限的。通过分区可以将数据分散到多个Redis实例中,理论上可以不受单机内存的限制,从而存储更多的数据。例如,一个电商平台的商品缓存数据量巨大,单台Redis服务器无法容纳,
- Redis面试题----MySQL 里有 2000w 数据,Redis 中只存 20w 的数据,如何保证 Redis 中的数据都是热点数据?
指尖下的技术
Java面试题redismysql数据库
要保证Redis中存储的20w数据都是热点数据,可以从数据筛选和数据淘汰两个大的方面来考虑,以下是详细的实现思路和方法:数据筛选1.基于业务规则分析业务场景:不同的业务场景有不同的热点数据特征。例如,在电商系统中,热门商品、促销商品往往是热点数据;在新闻资讯系统中,最新发布、阅读量高的新闻是热点数据。根据业务的特点,确定热点数据的规则。定期同步:编写脚本或程序,根据业务规则从MySQL中筛选出符合
- docker下载redis,zookeeper,kafka超时time out
林小夕success
dockerrediszookeeper
最新地址将registry-mirrors相关复制进去即可,这些地址下载不会超时。{“builder”:{“gc”:{“defaultKeepStorage”:“20GB”,“enabled”:true}},“experimental”:false,“features”:{“buildkit”:true},“registry-mirrors”:[“https://do.nark.eu.org”,“
- MySQL表的连接
011eH
mysql数据库database
MySQL知识总结在Github上查看《MySQL是怎样运行的》知识总结单表访问方法表的连接原理优化基于查询成本的优化优化需要的统计数据优化基于规则的优化Explain详解InnoDB缓冲区事务redo日志undo日志MVCC原理MySQL锁11连接原理表的结构createtablet1(m1int,n1char(1));createtablet2(m2int,n2char(1));inserti
- MySQL数据库入门:从零开始掌握数据库基础
心随_风动
数据库数据库mysql
MySQL数据库入门:从零开始掌握数据库基础@[TOC](MySQL数据库入门:从零开始掌握数据库基础)什么是MySQL?为什么学习MySQL?MySQL的核心概念1.数据库(Database)2.表(Table)3.字段(Field)4.记录(Record)5.SQL(StructuredQueryLanguage)MySQL的安装与配置1.下载MySQL2.安装MySQL3.启动MySQL服务
- Spring Boot整合MyBatis
BugAndWarning
SpringBoot的学习springbootmybatistomcatintellijideajava服务器后端
SpringBoot整合MyBatis在SpringBoot项目中,使用MyBatis是一种十分流行的数据访问方式。相对于Javaweb通过原生JDBC访问数据库,MyBatis的操作会非常的简单。原生JDBC访问数据库使用原生JDBC进行数据库操作如下:加载数据库驱动程序。获取数据库连接。创建Statement/PreparedStatement对象。执行SQL语句。处理查询结果。关闭资源。使用
- Hive SQL 使用及进阶详解
小四的快乐生活
hivesqlhadoop
一、Hive简介Hive是建立在Hadoop之上的数据仓库基础架构,它提供了类似于SQL的查询语言HiveSQL(也称为HQL),用于对存储在Hadoop分布式文件系统(HDFS)中的大规模数据进行数据查询和分析。Hive将SQL查询转换为MapReduce、Tez或Spark等分布式计算任务,使得不熟悉Java编程的数据分析人员也能方便地处理大规模数据。二、HiveSQL基础使用(一)环境准备在
- redis基础篇——Lua脚本
石灰聪
redisredis
Lua脚本Lua是一种轻量级脚本语言,它是用C语言编写的,跟数据的存储过程有点类似。使用Lua脚本来执行Redis命令的好处:1、一次发送多个命令,减少网络开销。2,Redis会将整个脚本作为一个整体执行,不会被其他请求打断,保持原子性。3、对于复杂的组合命令,我们可以放在文件中,可以实现命令复用。语法格式redis>evallua-scriptkey-num[key1key2key3...][v
- CSS3过渡效果小练习-进度条
nuomi_w
css3css前端
Document.bar{width:150px;height:15px;border:1pxsolidred;border-radius:7px;}.bar_in{width:50%;height:100%;background-color:red;transition:all0.8s;}.bar:hover.bar_in{width:100%;border-radius:7px;}
- Redisson 简介
茶本无香
redis
1.Redisson简介Redisson是一个基于Redis的Java客户端库,专注于分布式和并发编程。它提供了丰富的分布式对象和服务(如分布式锁、集合、队列、限流器等),简化了Redis在分布式系统中的使用。2.核心功能2.1分布式锁可重入锁:支持线程重入和自动续期(看门狗机制)。公平锁:按请求顺序获取锁。联锁(MultiLock):同时锁定多个资源。红锁(RedLock):多节点容错锁。代码示
- 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设计
这篇内容其实没有经过太多的深思熟虑,只是个人一时的感觉。从个人风格上来讲,我倾向简单质朴的设计开发理念;从方法论上,我更加倾向自顶向下的设计;从做事情的目标上来看,我追求质量优先,更愿意使用较为保守和稳妥的理念和方法。
&