- 蓝桥杯Python组最后几天冲刺———吐血总结,练题总结,很管用我学会了
晚风时亦鹿
学习笔记Python算法笔记python
一、重要知识要点1、穷举法2、枚举法3、动态规划4、回溯法5、图论6、深度优先搜索(DFS)7、广度优先搜索(BFS)8、二叉树9、递归10、分治法、矩阵法11、排列组合12、素数、质数、水仙花数13、欧几里得定理gcd14、求最大公约数、最小公倍数15、海伦公式(求三角形面积)16、博弈论17、贪心18、二分查找法19、hash表20、日期计算21、矩形快速幂22、树形DP23、最短路径24、最
- Swift语言的多线程编程
Code侠客行
包罗万象golang开发语言后端
Swift语言的多线程编程在现代软件开发中,多线程编程是提高应用性能和响应速度的重要手段。尤其是在iOS和macOS开发中,由于用户界面(UI)的交互性和复杂性,合理利用多线程可以极大地提升用户体验。本文将深入探讨Swift语言中的多线程编程机制,包括GCD(GrandCentralDispatch)、NSOperation、线程的基本概念及其使用场景。一、什么是多线程多线程是一种程序设计理念,通
- Python内置模块-Math
-MaoKe-
Python模块python前端
文章目录Python内置模块-Math一、模块介绍二、数值运算1.math.ceil()2.math.floor()3.math.fabs()4.math.modf()5.math.trunc()6.math.factorial()7.math.fmod()8.math.fsum()9.math.gcd()10.math.frexp()11.math.ldexp()12.math.copysign
- 2807. 在链表中插入最大公约数
不玩return的马可乐
链表数据结构leetcode算法职场和发展c++
在本篇博客文章中,我们将探讨如何实现一个算法,该算法可以在链表中相邻节点之间插入一个新的节点,新节点的值为相邻两个节点值的最大公约数(GCD)。这个问题是LeetCode上的一个中等难度问题,涉及到链表操作和最大公约数的计算。问题描述解题思路理解问题首先,我们需要理解问题的核心:在链表的相邻节点之间插入新节点,新节点的值为相邻节点值的最大公约数。计算最大公约数我们需要一个函数来计算两个数的最大公约
- 最详细G1垃圾回收器日志解读
齐梦星空
jvm
首先,开启gc日志。-XX:+PrintGCDetails疏散阶段疏散阶段,主要是将内存中的数据从一些分区复制到其他分区0.522:[GCpause(young),0.15877971secs]#这次疏散只涉及年轻代,总耗时0.15877971.如果是混合gc则可能是[GCpause(mixed),0.32714353secs][ParallelTime:157.1ms]#并行疏散,总耗时157.
- G1原理—G1的GC日志分析解读
液态不合群
jvmjava算法
1.TLAB的GC日志解读(1)一套基本的参数设置首先参数上要有一套基本的设置:-XX:InitialHeapSize=128M-XX:MaxHeapSize=128M-XX:+UseG1GC-XX:+PrintGCDetails-XX:+PrintGCTimeStamps-XX:+PrintTLAB-XX:+UnlockExperimentalVMOptions-XX:G1LogLevel=fi
- ios GCD
_Waiting_
1.GCD任务和队列学习GCD之前,先来了解GCD中两个核心概念:任务和队列。任务:就是执行操作的意思,换句话说就是你在线程中执行的那段代码。在GCD中是放在block中的。执行任务有两种方式:同步执行(sync)和异步执行(async)。两者的主要区别是:是否等待队列的任务执行结束,以及是否具备开启新线程的能力。同步执行(sync):同步添加任务到指定的队列中,在添加的任务执行结束之前,会一直等
- Codeforces Round 969 (Div. 2) C. Dora and C++ (裴蜀定理)
致碑前繁花
刷题记录c语言c++开发语言
什么?竟然是裴蜀定理。。。由于这里给出了a和b两个数,我们或许可以想到使用同样是需要给出两个定值的裴蜀定理,即:如果给定xxx和yyy,那么一定有ax+by=gcd(x,y)ax+by=gcd(x,y)ax+by=gcd(x,y)。所以在这时候我们就可以让输入的所有数都去对gcd(a,b)gcd(a,b)gcd(a,b)取模,这样就能够得到所有数的最简形式(可以当成是让所有数尽可能消去aaa和bb
- PTA:7-32 最小公倍数(递归)
萠哥啥都行
java开发语言
本题目要求读入2个整数a和b,然后输出它们的最小公倍数。输入格式:输入在一行中给出2个正整数,以空格分隔。输出格式:输出最小公倍数。输入样例:在这里给出一组输入。例如:614输出样例:在这里给出相应的输出。例如:42importjava.util.Scanner;publicclassMain{publicstaticintgcd(inta,intb){//辗转相除求最大公约数if(b==0){r
- iOS GCD底层分析(2)--同步异步函数、死锁、GCD单例
冼同学
前言上一篇文章iOSGCD底层分析(1)留下了四个问题,分别是:死锁底层是怎么样子产生的?如果是异步函数,线程是怎样子创建的?底层通过_dispatch_worker_thread2方法完成任务的回调执行,那么触发调用的位置在哪?单例的底层原理是什么?准备工作libdispatch.dylibiOSGCD底层分析(1)1.同步函数上一篇文章中分系同步函数时进入了_dispatch_sync_f_i
- Python【math数学函数】
Alan_Lowe
#Pythonpython
Python【math数学函数】文章目录Python【math数学函数】数论与表示函数1.ceil()和floor()2.comb()3.copysign()4.fabs()5.factorial()6.gcd()7.lcm()幂函数与对数函数1.exp()和math.e和pow()2.log()和log2()和log10()3.sqrt(x)三角函数1.asin、acos()、atan()2.s
- dispatch_once源码分析
福伟_Y
GCD里的单例函数dispatch_once是我们经常会用到的,今天我们来稍做深入分析一下。GCD的源码都在libdispatch.dylib库里,这个库在libSystem_initializer被初始化,可理解为在dyld里被加载和初始化的(之前的文章有分析过)。dispatch_once作为单例的使用入口,通过分析得到它是一个宏定义,_dispatch_once函数在libdispatch.
- python求两个数的最大公约数穷举法_最大公约数GCD算法
weixin_39789101
采用Python实现四种最大公约数(greatestcommondivisor)算法,并比较评估性能。算法原理:1、辗转相除法:已知a,b,c为正整数,若a除以b余c,则GCD(a,b)=GCD(b,c)。2、更相减损术:任意给定两个正整数,若是偶数,则用2约简。以较大的数减较小的数,接着把所得的差与较小的数比较,并以大数减小数。继续这个操作,直到所得的减数和差相等为止。3、除穷举法:将小数依次除
- python用递归方式实现最大公约数_Python - 最大公约数算法
weixin_39765325
#Python3.6#最大公约数,最大公因子#GreatestCommonDivisor#辗转相除法defgcd(num1:object,num2:object)->object:print('num1={},num2={},r={}'.format(num1,num2,num1%num2))ifnum1%num2==0:returnnum2returngcd(num2,num1%num2)#更相
- 【iOS】GCD详解
cheng_lin0201
OCiOSiosobjective-c
初识GCD深入理解GrandCentralDispatch(GCD):iOS多线程编程的利器前言1.GCD简介1.1什么是GCD?1.2为什么使用GCD?2.GCD的核心概念2.1任务与队列2.2串行队列与并发队列3.GCD的API3.1DispatchQueue3.2dispatch_queue_create3.3MainDispatchQueue&GlobalDispatchQueue3.4d
- 数论——扩展欧几里得算法
NOI_yzk
欧几里得&拓展欧几里得(Euclid&Extend-Euclid)欧几里得算法(Euclid)背景:欧几里德算法又称辗转相除法,用于计算两个正整数a,b的最大公约数。——百度百科代码:递推的代码是相当的简洁:intgcd(inta,intb){returnb==0?a:gcd(b,a%b);}分析:方法说了是辗转相除法,自然没有什么好介绍的了。。Fresh肯定会觉得这样递归下去会不会爆栈?实际上在
- 多线程
reboot_q
线程一个进程要想执行任务,就必须开启线程.一个线程同一时间只能执行一个任务(线程内部是串行的).多线程CPU通过操控多个线程切换,并行执行任务!提高效率;线程开销,耗性能,发热耗电;主线程UI线程,刷新UI界面,处理点击事件;防止线程阻塞.FirstHeaderSecondHeaderpthreadCNSThreadOCGCDCNSOperationC线程的状态runnable,running,b
- [SwiftUI 开发] Actor 陷阱
文件夹__iOS
swiftuiiosswift
什么是Actor?在Swift中,actor通过按顺序一次处理一个任务来避免数据竞争。这意味着,尽管你可能已经在多个不同的地方同时调度了对actor的访问,但这些访问不会同时占用actor的状态。这一点类似于串行队列在GCD(GrandCentralDispatch)中的处理方式,但actor提供了更强大和直观的功能。Actor在reentrancy需要注意的问题我们先看一个domeactorCo
- iOS面试题(三)
WinJayQ
1、Objective-C中创建线程的方法是什么?如果在主线程中执行代码,方法是什么?如果想延时执行代码、方法又是什么?线程创建有三种方法:使用NSThread创建、使用GCD的dispatch、使用子类化的NSOperation,然后将其加入NSOperationQueue;在主线程执行代码,方法是performSelectorOnMainThread,如果想延时执行代码可以用performSe
- 第十三届蓝桥杯省赛C&C++ 研究生组
Moliay
蓝桥杯蓝桥杯c语言c++
蓝桥杯2022年第十三届省赛真题-裁纸刀蓝桥杯2022年第十三届省赛真题-灭鼠先锋蓝桥杯2022年第十三届省赛真题-质因数个数求个数,则只需要计数即可。求啥算啥,尽量不要搞多余操作蓝桥杯2022年第十三届省赛真题-选数异或蓝桥杯2022年第十三届省赛真题-GCD蓝桥杯2022年第十三届省赛真题-全排列的价值蓝桥杯2022年第十三届省赛真题-数的拆分蓝桥杯2022年第十三届省赛真题-重复的数
- 坎坎坷坷
我脖子呢
http://47.95.208.3:8089/mobile.html#/?_=bffifjehfegcdaaaa
- Visual Studio清单作用
白衫长发时光与她
vsvisualstudioide
1、作用:制定程序依赖的C运行库的dll及版本,包括mfc,atl,crt等,在VisualStudio安装目录下的vc/redist下有debug和release版本2、确定应用程序依赖哪些visualC++库方法:查看项目-》项目设置-》常规,可以看到项目使用的是MFC和ATL库,如果过选择“在动态库中使用MFC”,则程序依赖MGCdll,如果不使用MFC或ATL,仍然可能依赖CRT库(如果在
- python - 模块
tanyyinyu
python开发语言
root@learning~]#catgcdfunction.py#写一个模块,并调用此模块defgcd(n1,n2):#之前用过的求最大公约数的代码gcd=1k=2whilek<=n1andk<=n2:ifn1%k==0andn2%k==0:gcd=kk=k+1returngcd[root@learning~]#catmodule.py#完整代码fromgcdfunctionimportgcd#
- LeetCode 2427. 公因子的数目
吃着火锅x唱着歌
LeetCodeleetcode算法职场和发展
给你两个正整数a和b,返回a和b的公因子的数目。如果x可以同时整除a和b,则认为x是a和b的一个公因子。示例1:输入:a=12,b=6输出:4解释:12和6的公因子是1、2、3、6。1<=a,b<=1000classSolution{public:intcommonFactors(inta,intb){//找出a和b的最大公因数,其他所有因数都会小于最大公因数intg=gcd(a,b);inti=
- 【洛谷题解】P1029[普及组]最大公约数和最小公倍数问题
杨智123
算法数据结构
题目链接:[NOIP2001普及组]最大公约数和最小公倍数问题-洛谷题目难度:普及-涉及知识点:stl函数,最大公因数,最小公倍数题意:输入输出样例:分析:直接套用公式优化累加即可AC代码:#include//可使用STL函数:__gcd判断最大公因数usingnamespacestd;intmain(){inta,b,ans=0;ios::sync_with_stdio(false);//加快c
- 【Effective Objective - C】—— block 块
《杯莫停》
c语言cocoaios
【EffectiveObjective-C】——block块前言37.理解块的概念块的基础知识块可以捕获变量内联块的用法块的内部结构栈块堆块全局块要点38.为常用的块类型创建typedef要点39.用handler块降低代码分散程度协议传值实现异步块实现异步回调操作里的块要点40.用块引用其所属对象时不要出现保留环块中也存在保留环要点前言本章的内容是比较麻烦复杂的一章,牵扯到了GCD和Block,
- 【iOS】GCD学习
温柔何曾赋我
ios学习
文章目录前言一、什么是GCD二、任务和队列三、GCD基本使用队列的创建任务的创建任务和队列的组合同步任务+串行队列异步任务+串行队列异步任务+并发队列主队列+同步任务主队列+异步任务四、MainDispatchQueue&GlobalDispatchQueue五、dispatch_set_target_queue函数六、dispatch_after七、DispatchGroup八、GCD栅栏方法:
- 利用GCD写了一个倒计时的例子
小小旭
__blockinttimeOut=[endTimeStrintValue];//倒计时时间dispatch_queue_tqueue=dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0);dispatch_source_t_timer=dispatch_source_create(DISPATCH_SOURCE_TYPE_TIM
- ARC159B GCD Subtraction
dygxczn
算法
题目这里有一个性质,对于互质的两个数a,ba,ba,b,它们的答案与ag,bgag,bgag,bg两数的答案相等。设ag,bgag,bgag,bg第iii操作减去的数xxx;a,ba,ba,b第iii次操作减去的数为yyy,显然有x=gyx=gyx=gy,前者减去的数是后者的ggg倍,而ag,bgag,bgag,bg又恰好是a,ba,ba,b的ggg倍,得证。所以我们可以先把a,ba,ba,b除以
- Effective Objective-C 学习(四)
糸师凛
objective-c学习ios
掌握GCD及操作队列的使用时机在执行后台任务时,GCD并不一定是最佳方式。还有一种技术叫做NSOperationQueue,它虽然与GCD不同,但是却与之相关,开发者可以把操作以NSOperation子类的形式放在队列中,而这些操作也能够并发执行。GCD是纯C的API,而NSOperationQueue是Objective-C的对象。这意味着使用GCD时,任务通过块(block)来表示,而块是一种
- PHP如何实现二维数组排序?
IT独行者
二维数组PHP排序
二维数组在PHP开发中经常遇到,但是他的排序就不如一维数组那样用内置函数来的方便了,(一维数组排序可以参考本站另一篇文章【PHP中数组排序函数详解汇总】)。二维数组的排序需要我们自己写函数处理了,这里UncleToo给大家分享一个PHP二维数组排序的函数:
代码:
functionarray_sort($arr,$keys,$type='asc'){
$keysvalue= $new_arr
- 【Hadoop十七】HDFS HA配置
bit1129
hadoop
基于Zookeeper的HDFS HA配置主要涉及两个文件,core-site和hdfs-site.xml。
测试环境有三台
hadoop.master
hadoop.slave1
hadoop.slave2
hadoop.master包含的组件NameNode, JournalNode, Zookeeper,DFSZKFailoverController
- 由wsdl生成的java vo类不适合做普通java vo
darrenzhu
VOwsdlwebservicerpc
开发java webservice项目时,如果我们通过SOAP协议来输入输出,我们会利用工具从wsdl文件生成webservice的client端类,但是这里面生成的java data model类却不适合做为项目中的普通java vo类来使用,当然有一中情况例外,如果这个自动生成的类里面的properties都是基本数据类型,就没问题,但是如果有集合类,就不行。原因如下:
1)使用了集合如Li
- JAVA海量数据处理之二(BitMap)
周凡杨
java算法bitmapbitset数据
路漫漫其修远兮,吾将上下而求索。想要更快,就要深入挖掘 JAVA 基础的数据结构,从来分析出所编写的 JAVA 代码为什么把内存耗尽,思考有什么办法可以节省内存呢? 啊哈!算法。这里采用了 BitMap 思想。
首先来看一个实验:
指定 VM 参数大小: -Xms256m -Xmx540m
- java类型与数据库类型
g21121
java
很多时候我们用hibernate的时候往往并不是十分关心数据库类型和java类型的对应关心,因为大多数hbm文件是自动生成的,但有些时候诸如:数据库设计、没有生成工具、使用原始JDBC、使用mybatis(ibatIS)等等情况,就会手动的去对应数据库与java的数据类型关心,当然比较简单的数据类型即使配置错了也会很快发现问题,但有些数据类型却并不是十分常见,这就给程序员带来了很多麻烦。
&nb
- Linux命令
510888780
linux命令
系统信息
arch 显示机器的处理器架构(1)
uname -m 显示机器的处理器架构(2)
uname -r 显示正在使用的内核版本
dmidecode -q 显示硬件系统部件 - (SMBIOS / DMI)
hdparm -i /dev/hda 罗列一个磁盘的架构特性
hdparm -tT /dev/sda 在磁盘上执行测试性读取操作
cat /proc/cpuinfo 显示C
- java常用JVM参数
墙头上一根草
javajvm参数
-Xms:初始堆大小,默认为物理内存的1/64(<1GB);默认(MinHeapFreeRatio参数可以调整)空余堆内存小于40%时,JVM就会增大堆直到-Xmx的最大限制
-Xmx:最大堆大小,默认(MaxHeapFreeRatio参数可以调整)空余堆内存大于70%时,JVM会减少堆直到 -Xms的最小限制
-Xmn:新生代的内存空间大小,注意:此处的大小是(eden+ 2
- 我的spring学习笔记9-Spring使用工厂方法实例化Bean的注意点
aijuans
Spring 3
方法一:
<bean id="musicBox" class="onlyfun.caterpillar.factory.MusicBoxFactory"
factory-method="createMusicBoxStatic"></bean>
方法二:
- mysql查询性能优化之二
annan211
UNIONmysql查询优化索引优化
1 union的限制
有时mysql无法将限制条件从外层下推到内层,这使得原本能够限制部分返回结果的条件无法应用到内层
查询的优化上。
如果希望union的各个子句能够根据limit只取部分结果集,或者希望能够先排好序在
合并结果集的话,就需要在union的各个子句中分别使用这些子句。
例如 想将两个子查询结果联合起来,然后再取前20条记录,那么mys
- 数据的备份与恢复
百合不是茶
oraclesql数据恢复数据备份
数据的备份与恢复的方式有: 表,方案 ,数据库;
数据的备份:
导出到的常见命令;
参数 说明
USERID 确定执行导出实用程序的用户名和口令
BUFFER 确定导出数据时所使用的缓冲区大小,其大小用字节表示
FILE 指定导出的二进制文
- 线程组
bijian1013
java多线程threadjava多线程线程组
有些程序包含了相当数量的线程。这时,如果按照线程的功能将他们分成不同的类别将很有用。
线程组可以用来同时对一组线程进行操作。
创建线程组:ThreadGroup g = new ThreadGroup(groupName);
&nbs
- top命令找到占用CPU最高的java线程
bijian1013
javalinuxtop
上次分析系统中占用CPU高的问题,得到一些使用Java自身调试工具的经验,与大家分享。 (1)使用top命令找出占用cpu最高的JAVA进程PID:28174 (2)如下命令找出占用cpu最高的线程
top -Hp 28174 -d 1 -n 1
32694 root 20 0 3249m 2.0g 11m S 2 6.4 3:31.12 java
- 【持久化框架MyBatis3四】MyBatis3一对一关联查询
bit1129
Mybatis3
当两个实体具有1对1的对应关系时,可以使用One-To-One的进行映射关联查询
One-To-One示例数据
以学生表Student和地址信息表为例,每个学生都有都有1个唯一的地址(现实中,这种对应关系是不合适的,因为人和地址是多对一的关系),这里只是演示目的
学生表
CREATE TABLE STUDENTS
(
- C/C++图片或文件的读写
bitcarter
写图片
先看代码:
/*strTmpResult是文件或图片字符串
* filePath文件需要写入的地址或路径
*/
int writeFile(std::string &strTmpResult,std::string &filePath)
{
int i,len = strTmpResult.length();
unsigned cha
- nginx自定义指定加载配置
ronin47
进入 /usr/local/nginx/conf/include 目录,创建 nginx.node.conf 文件,在里面输入如下代码:
upstream nodejs {
server 127.0.0.1:3000;
#server 127.0.0.1:3001;
keepalive 64;
}
server {
liste
- java-71-数值的整数次方.实现函数double Power(double base, int exponent),求base的exponent次方
bylijinnan
double
public class Power {
/**
*Q71-数值的整数次方
*实现函数double Power(double base, int exponent),求base的exponent次方。不需要考虑溢出。
*/
private static boolean InvalidInput=false;
public static void main(
- Android四大组件的理解
Cb123456
android四大组件的理解
分享一下,今天在Android开发文档-开发者指南中看到的:
App components are the essential building blocks of an Android
- [宇宙与计算]涡旋场计算与拓扑分析
comsci
计算
怎么阐述我这个理论呢? 。。。。。。。。。
首先: 宇宙是一个非线性的拓扑结构与涡旋轨道时空的统一体。。。。
我们要在宇宙中寻找到一个适合人类居住的行星,时间非常重要,早一个刻度和晚一个刻度,这颗行星的
- 同一个Tomcat不同Web应用之间共享会话Session
cwqcwqmax9
session
实现两个WEB之间通过session 共享数据
查看tomcat 关于 HTTP Connector 中有个emptySessionPath 其解释如下:
If set to true, all paths for session cookies will be set to /. This can be useful for portlet specification impleme
- springmvc Spring3 MVC,ajax,乱码
dashuaifu
springjquerymvcAjax
springmvc Spring3 MVC @ResponseBody返回,jquery ajax调用中文乱码问题解决
Spring3.0 MVC @ResponseBody 的作用是把返回值直接写到HTTP response body里。具体实现AnnotationMethodHandlerAdapter类handleResponseBody方法,具体实
- 搭建WAMP环境
dcj3sjt126com
wamp
这里先解释一下WAMP是什么意思。W:windows,A:Apache,M:MYSQL,P:PHP。也就是说本文说明的是在windows系统下搭建以apache做服务器、MYSQL为数据库的PHP开发环境。
工欲善其事,必须先利其器。因为笔者的系统是WinXP,所以下文指的系统均为此系统。笔者所使用的Apache版本为apache_2.2.11-
- yii2 使用raw http request
dcj3sjt126com
http
Parses a raw HTTP request using yii\helpers\Json::decode()
To enable parsing for JSON requests you can configure yii\web\Request::$parsers using this class:
'request' =&g
- Quartz-1.8.6 理论部分
eksliang
quartz
转载请出自出处:http://eksliang.iteye.com/blog/2207691 一.概述
基于Quartz-1.8.6进行学习,因为Quartz2.0以后的API发生的非常大的变化,统一采用了build模式进行构建;
什么是quartz?
答:简单的说他是一个开源的java作业调度框架,为在 Java 应用程序中进行作业调度提供了简单却强大的机制。并且还能和Sp
- 什么是POJO?
gupeng_ie
javaPOJO框架Hibernate
POJO--Plain Old Java Objects(简单的java对象)
POJO是一个简单的、正规Java对象,它不包含业务逻辑处理或持久化逻辑等,也不是JavaBean、EntityBean等,不具有任何特殊角色和不继承或不实现任何其它Java框架的类或接口。
POJO对象有时也被称为Data对象,大量应用于表现现实中的对象。如果项目中使用了Hiber
- jQuery网站顶部定时折叠广告
ini
JavaScripthtmljqueryWebcss
效果体验:http://hovertree.com/texiao/jquery/4.htmHTML文件代码:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>网页顶部定时收起广告jQuery特效 - HoverTree<
- Spring boot内嵌的tomcat启动失败
kane_xie
spring boot
根据这篇guide创建了一个简单的spring boot应用,能运行且成功的访问。但移植到现有项目(基于hbase)中的时候,却报出以下错误:
SEVERE: A child container failed during start
java.util.concurrent.ExecutionException: org.apache.catalina.Lif
- leetcode: sort list
michelle_0916
Algorithmlinked listsort
Sort a linked list in O(n log n) time using constant space complexity.
====analysis=======
mergeSort for singly-linked list
====code======= /**
* Definition for sin
- nginx的安装与配置,中途遇到问题的解决
qifeifei
nginx
我使用的是ubuntu13.04系统,在安装nginx的时候遇到如下几个问题,然后找思路解决的,nginx 的下载与安装
wget http://nginx.org/download/nginx-1.0.11.tar.gz
tar zxvf nginx-1.0.11.tar.gz
./configure
make
make install
安装的时候出现
- 用枚举来处理java自定义异常
tcrct
javaenumexception
在系统开发过程中,总少不免要自己处理一些异常信息,然后将异常信息变成友好的提示返回到客户端的这样一个过程,之前都是new一个自定义的异常,当然这个所谓的自定义异常也是继承RuntimeException的,但这样往往会造成异常信息说明不一致的情况,所以就想到了用枚举来解决的办法。
1,先创建一个接口,里面有两个方法,一个是getCode, 一个是getMessage
public
- erlang supervisor分析
wudixiaotie
erlang
当我们给supervisor指定需要创建的子进程的时候,会指定M,F,A,如果是simple_one_for_one的策略的话,启动子进程的方式是supervisor:start_child(SupName, OtherArgs),这种方式可以根据调用者的需求传不同的参数给需要启动的子进程的方法。和最初的参数合并成一个数组,A ++ OtherArgs。那么这个时候就有个问题了,既然参数不一致,那