- ios c语言调用oc方法,ios-面试-OC 方法调用的过程原理
weixin_39615419
iosc语言调用oc方法
OC中的所有方法调用,最终都是转换成runtime中的一个C语言消息分发函数:objc_msgSend(消息接收者,方法名,参数。。。)这条消息发送之后,系统会在receiver的类对象的方法列表中找这个方法,如果没找到,再到receiver的父类的方法列表中找,如此直到根类至找到为止,如果还没有找到会报出错误。(缓存:方法第一次被调用之后,方法会被存入一张缓存表,之后如果再被调用时就直接从缓存表
- objc_msgSend 动态查找
Jonnyking
1.objc_class的chache找2.在对象的方法列表里找3.去父类指针指向的对象中去执行1.24.直到根类也没找到就消息转发5.调用resolveInstanceMethod让类添加这个方法的实现6.forwardingTargetForSelector让对象执行这个函数7.forwordInvocation更灵活的处理函数调用8.都没找到doesNotRecognizeSelector
- 【Effective Objective - C 2.0】——读书笔记(二)
温柔何曾赋我
c语言iosobjective-c
文章目录前言六、理解“属性”这一概念七、在对象内部尽量直接访问实例变量八、理解“对象等同性”这一概念九、以“类族模式”隐藏实现细节十、在既有类中使用关联对象存放自定义数据十一、理解objc_msgSend的作用十二、理解消息转发机制动态方法解析备援接受者完整的消息转发消息转发全流程十四、理解“类对象”的用意前言这是一篇为了快手✌️xmy学长写的博客六、理解“属性”这一概念“属性”(property
- OC中的Category(三)
aaayia
OC中的Category(三)OC中+initialize函数加载和调用OC对象是在查找方法时判断自己有没有初始化,如果没有就会调用初始化方法,在调用自己的初始化方法之前会调用父类的初始化方法。调用initialize方法是通过runtime的objc_msgSend的方式调用,所以会存在如果子类没有实现会调用父类的initialize方法,并且优先调用类分类中存在的initializ方法+ini
- objc_msgSend流程分析
会跑的鱼_09
背景如果大家用clang编译编译过oc的代码,你会发现oc的所有方法调用最终都都转换成了objc_msgSend,而它内部是如何实现的呢,对于我们开发过程中经常遇到的unrecognizedselectorsenttoinstance这个方法未实现异常又是如何出现的呢,今天我们就来剖析一下整个流程吧~先总结一下objc_msgSend整体流程的四个阶段:快速查找慢速查找动态方法决议消息转发下面我们
- Objc_msgSend流程
_涼城
在了解objc_msgSend之前,需要先了解runtime。Runtime是一套底层纯C语言API,Objective-C代码最终都会被编译器转化为运行时代码,通过消息机制决定函数调用方式。那么什么是运行时呢?运行时就是程序已经装载在内存中,与编译时不同的是,运行时在内存中做操作以及判断。Objective-C是一门动态语言,就是因为它总是把一些决定性的工作从编译阶段推迟到运行时阶段。OC代码的
- iOS--经典问题:runtime三种调用方式
OXHO
创建一个OC项目,创建项目目录结构对象方法调用源码如下:main.m#import#import"Person.h"#includeintmain(intargc,constchar*argv[]){@autoreleasepool{//insertcodehere...Person*p=[[Personalloc]init];[prun];objc_msgSend(p,sel_registerN
- ios runtime入门
Mjs
runtime:运行时机制学的有点凌乱,记一下runtime是OC的底层,一套纯C的api,我们平时写的OC代码,都会通过runtime编译成C语言导入#import包含#include图1在buildsetting中搜索msg把选项改为NO否者会不出现提示且报错。OC通过消息发送进行传递的objc_msgSend(class,SEL,arg1,arg2,...);class:消息的接收者,SEL
- Objective-C:Runtime
zhouluyao
objc_msgSend底层调用有3大阶段1.消息发送objc_msgSend执行流程01-消息发送.png2.动态方法解析objc_msgSend执行流程02-动态方法解析.pngvoidc_other(idself,SEL_cmd){NSLog(@"c_other-%@-%@",self,NSStringFromSelector(_cmd));}-(void)other{NSLog(@"%s"
- Effective oc 2.0 第二章学习--对象、消息、运行期
菜的不敢吱声
学习iosobjective-c
Effectiveoc2.0第二章学习--对象、消息、运行期前言理解属性这一概念属性特质原子性读写权限内存管理语义方法名注意的点要点在对象内部尽量直接访问实例变量注意的点要点理解“对象等同性”这一概念特定类所具有的等同性判断方法等同性判断的执行深度理解objc_msgSend的作用要点理解消息转发机制动态方法解析备援接收者完整的消息转发消息转发全流程要点用“方法调配技术”调试“黑盒方法”要点理解“
- oc 分类方法、+(void)load、+(void)initialize方法调用分析
森_ab60
分类同名方法调用原理1、分类方法在类被加载时由runtime插入到类对象/元类对象的methodList的前面2、多个分类时采用倒序遍历,把方法汇总到一个addedList数组中,所以最后参与编译的分类方法在addedList的最前面3、把2中的addedList的方法整体插入到类对象的methodList的最前面4、当上层在调用某个方法时通过objc_msgSend方法查找方法列表,找到方法入口
- 谈谈你对Runtime的理解
麟枫_Jack
1.讲一下oc的消息机制OC的方法调用其实都转成的objc_magSend函数的调用,给方法调用者发送一条消息objc_msgSend底层有3大阶段:消息发送(从当前类父类中查找)、动态方法解析、消息转发2.什么是runtime?OC是一门动态性编程语言,允许很多操作推迟到运行时在进行OC的动态性是有RunTime来支撑和实现的,Runtime是一套C语言的API,封装了很多动态性相关的函数平时编
- IOS开发谈谈对Runtime 和 Runloop的理解
谢千域
RuntimeRuntime简称运行时,OC就是运行时机制,也就是在运行时候的一些机制,其中最重要的事消息机制。作用消息机制原理:对象根据方法编号SEL去映射表查找对应的方法实现方法调用的本质就是让对象发送消息objc_msgSend,只用对象才能发送消息,因此以objc开头。使用消息机制前提,必须导入#import使用场景交换方法动态添加方法给分类添加属性字典转模型:RuntimeRunLoop
- Objective-C Runtime Programming
农场主er
#Objective-Ciosobjective-c
参考资料:Objective-CRuntimeProgrammingGuide1、MessagingOC中执行方法的形式为:[receivermessage],运行时绑定方法的具体实现。编译器将其转化为:objc_msgSend(receiver,selector,arg1,arg2,...)。调用实现方法时会多传入两个隐藏参数:_cmd:对应方法的selectorself:调用方法的对象编译器为
- OC,objc_msgSend()函数做了哪些事
BangRaJun
OC,objc_msgSend()简介:用一句话简介消息传递那就是:用一个C语言函数,向一个实例传递一个字符串,实例拿到字符串后与自己的method_list中的SEL比较,遇到一样的就找到对应IMP执行。SEL就是一个字符串,IMP就是一个函数指针,在一个Method结构体中封装着这两者,因此他俩一一对应。在向一个实例发送消息时[objdoSomthing];实际上是调用的这个函数objc_ms
- oc-底层原理之objc_msgSend方法快速查找
沉默Coder
在oc-底层原理分析之Cache_t一文中我们对方法的缓存进行了探讨,这篇文章我们在来研究一下方法的查找方法的查找有两条线路:快速查找(通过汇编实现)慢速查找(通过c实现)(下一篇文章再来探究)方法快速查找方法的快速查找实际是通过缓存来查找,在探究之前,我们先来了解一下objc_msgSend,我们要知道方法的查找是在什么时机通过什么入口进入的objc_msgSend我们知道objective-c
- 深入解构objc_msgSend函数的实现
余青松
objc_class(Class对象)结构简介熟悉OC语言的Runtime(运行时)机制以及对象方法调用机制的开发者都知道,所有OC方法调用在编译时都会转化为对C函数objc_msgSend的调用。/*下面的例子是在arm64体系下的函数调用实现,本文中如果没有特殊说明都是指在arm64体系下的结论*///[view1addSubview:view2];objc_msgSend(view1,"ad
- iOS底层 -- Category本质之load、initialize方法
happy神悦
1.+load方法调用时刻+load方法会在runtime加载类、分类时调用每个类、分类的+load,在程序运行过程中只调用一次调用顺序先调用类的+load按照编译先后顺序调用(先编译,先调用)调用子类的+load之前会先调用父类的+load再调用分类的+load按照编译先后顺序调用(先编译,先调用)调用方式根据方法地址直接调用,并不是经过objc_msgSend函数调用2.+initialize
- objc_msgSend执行流程
xxxxxxxxx_ios
oc对象(包括类对象和实例对象)调用方法,主要有3个步骤,分别是消息发送,动态方法解析,消息转发1.消息发送消息发送2.动态方法解析动态方法解析说明其中YMPerson类的.h文件中声明一个-run方法,但.m文件没有进行方法的实现。如果直接调用YMPerson实例对象的run方法,会报找不到方法的崩溃。但在.m实现了+resolveInstanceMethod,并在其中动态添加了方法之后,实例对
- Xcode导入runtime框架函数参数没有提示或Too many arguments to function call, expected 0, have 2错误
月沉眠love
首先说明下,在Xcode6之前运用objc_msgSend,是有参数提示的。但是从Xcode6之后,苹果不推荐我们使用runtime,所以就取消了参数提示功能。估计是不想让我们过多的了解底层。我们可以通过对Xcode进行配置进行更改。更改如图屏幕快照2019-08-14下午3.52.38.png
- _lookUpImpOrForward慢速方法查找
冼同学
前言在《IOS底层原理之Runimte运行时&方法的本质》一文中已经分析了objc_msgSend查找缓存(cache)的流程,也就是objc_msgSend的快速查找流程,当cache中找不到imp的时候,就会进入慢速查找的过程。资料准备objc4-818.2源码Objective-CRuntimeobjc_msgSend_uncached流程实现当在cache中没有找到目标方法时候,汇编会进入
- iOS Runtime学习(二) -- Runtime执行顺序
Q海龙
一、什么是Runtime?OC是一门动态类型的语言,它允许很多操作都推迟到程序运行时再进行OC的动态性就是由Runtime来支撑和实现的,而Runtime是一套C语言的API,它封装了很多动态性相关的函数我们平时编写的OC代码,其实底层都是将代码转换成了RuntimeAPI来进行调用二、OC的消息机制OC的方法调用其实都是转成了objc_msgSend函数的调用,给方法的调用者发送了一条消息。ob
- 八、消息流程之慢速查找
Mlqq
在Object-C中调方法在底层就是调objc_msgSend进行发送消息,消息发送时先在Class的cache中查找imp,这一步为快速查找,在cache中没有找到,就会在bits中查找,这一步为慢速查找。1、慢速查找方法定位在结尾找到了MethodTableLookup,在搜索一下MethodTableLookup的定义:image.png这里只需要看bl_lookUpImpOrForward
- iOS底层探索四(isa初探-联合体,位域,内存优化)
ZhaiAlan
iOS底层iOS源码iOS开发objective-cios
前言相关文章:iOS底层探索一(底层探索方法)iOS底层探索二(OC中alloc方法初探)iOS底层探索三(内存对齐与calloc分析)iOS底层探索五(isa与类的关系)iOS底层探索六(类的分析上)iOS底层探索七(类的分析下)iOS底层探索八(方法本质上)iOS底层探索九(方法的本质下objc_msgSend慢速及方法转发初探)iOS底层探索十(方法的本质下-消息转发流程)相关代码:objc
- 一个实例对象调用方法的调用过程
_一叶孤帆
一个实例对象调用方法的调用过程编译->变成objc_msgSend(id,SEL,...)根据示例对象的isa指针,找到该对象的Class在Class中根据SEL方法名寻找函数实现IMP寻找过程先在当前类的cache中查找如果cache中没找到,就去当前类的methodLists列表中查找,最后根据superclass找到父类在父类的methhodLists中查找,直到找到NSObject为止,如
- 第十一节—objc_msgSend(三)动态决议
L_Ares
本文为L_Ares个人写作,以任何形式转载请表明原文出处。在第九节快速查找流程和第十节慢速查找流程之后,方法的查找流程就已经完成了。但是在第十节慢速查找流程的done之前的最后一步仍然没有找到方法的实现,还没有介绍。那一步就是本节的重点——动态决议,也叫动态方法解析。动态决议的目的是:给没有找到imp的类一次通过resolveInstanceMethod添加imp的机会。从而不进行崩溃的信息打印,
- Initialize方法底层实现
code_ce
initialize方法调用时机:initialize在类第一次接收到消息时调用,也就是objc_msgSend(),当一个类在查找方法的时候,会先判断当前类是否初始化,如果没有初始化就会去调用initialize方法。调用顺序:先调用父类的+initialize,再调用类放入initialize。调用次数:有可能是多次分类中的实现:只执行分类的调用类在调用initalize时,使用的是objc_
- iOS-底层原理-消息流程objc_msgSend分析之methodList(慢速查找)、动态方法决议、消息转发
如意神王
1.什么是慢速查找、动态方法决议、消息转发前面的博客介绍了,objs_msgSend查找cache的快速查找流程,即实例对象查找类对象cache,类对象查找元类对象的cache,也就是说,通过isa指向找到第一个查找节点的cache,进而汇编语言进行快速查找,那么第一个节点的methodList怎么查找,什么时候查找,后面父类的cache和methodList呢?父类的cache查找和我们前面分析
- iOS runtime使用
罗马危机
1.发送消息objc_msgSend(obj,@selector(func));调用实例方法objc_msgSend([Objclass],@selector(func));调用类方法2.交换方法//加载内存时调用+(void)load{//获取ImageOriginalWithStrName:方法MethodmyImageName=class_getClassMethod(self,@selec
- Objective-C的消息转发机制
我的昵称是小狼
1.Objective-C中方法的调用在Runtime期间,都会转为objc_msgSend(receiver,selector,arg1,arg2,...).默认的objc_msgSend会接收两个隐藏的参数,一个是消息接收者(一般默认为self),一个是方法(默认为_cmd).当objc_msgSend找不到方法的时候就会进入消息转发的流程1resolveInstanceMethod或reso
- 辗转相处求最大公约数
沐刃青蛟
C++漏洞
无言面对”江东父老“了,接触编程一年了,今天发现还不会辗转相除法求最大公约数。惭愧惭愧!
为此,总结一下以方便日后忘了好查找。
1.输入要比较的两个数a,b
忽略:2.比较大小(因为后面要的是大的数对小的数做%操作)
3.辗转相除(用循环不停的取余,如a%b,直至b=0)
4.最后的a为两数的最大公约数
&
- F5负载均衡会话保持技术及原理技术白皮书
bijian1013
F5负载均衡
一.什么是会话保持? 在大多数电子商务的应用系统或者需要进行用户身份认证的在线系统中,一个客户与服务器经常经过好几次的交互过程才能完成一笔交易或者是一个请求的完成。由于这几次交互过程是密切相关的,服务器在进行这些交互过程的某一个交互步骤时,往往需要了解上一次交互过程的处理结果,或者上几步的交互过程结果,服务器进行下
- Object.equals方法:重载还是覆盖
Cwind
javagenericsoverrideoverload
本文译自StackOverflow上对此问题的讨论。
原问题链接
在阅读Joshua Bloch的《Effective Java(第二版)》第8条“覆盖equals时请遵守通用约定”时对如下论述有疑问:
“不要将equals声明中的Object对象替换为其他的类型。程序员编写出下面这样的equals方法并不鲜见,这会使程序员花上数个小时都搞不清它为什么不能正常工作:”
pu
- 初始线程
15700786134
暑假学习的第一课是讲线程,任务是是界面上的一条线运动起来。
既然是在界面上,那必定得先有一个界面,所以第一步就是,自己的类继承JAVA中的JFrame,在新建的类中写一个界面,代码如下:
public class ShapeFr
- Linux的tcpdump
被触发
tcpdump
用简单的话来定义tcpdump,就是:dump the traffic on a network,根据使用者的定义对网络上的数据包进行截获的包分析工具。 tcpdump可以将网络中传送的数据包的“头”完全截获下来提供分析。它支 持针对网络层、协议、主机、网络或端口的过滤,并提供and、or、not等逻辑语句来帮助你去掉无用的信息。
实用命令实例
默认启动
tcpdump
普通情况下,直
- 安卓程序listview优化后还是卡顿
肆无忌惮_
ListView
最近用eclipse开发一个安卓app,listview使用baseadapter,里面有一个ImageView和两个TextView。使用了Holder内部类进行优化了还是很卡顿。后来发现是图片资源的问题。把一张分辨率高的图片放在了drawable-mdpi文件夹下,当我在每个item中显示,他都要进行缩放,导致很卡顿。解决办法是把这个高分辨率图片放到drawable-xxhdpi下。
&nb
- 扩展easyUI tab控件,添加加载遮罩效果
知了ing
jquery
(function () {
$.extend($.fn.tabs.methods, {
//显示遮罩
loading: function (jq, msg) {
return jq.each(function () {
var panel = $(this).tabs(&
- gradle上传jar到nexus
矮蛋蛋
gradle
原文地址:
https://docs.gradle.org/current/userguide/maven_plugin.html
configurations {
deployerJars
}
dependencies {
deployerJars "org.apache.maven.wagon
- 千万条数据外网导入数据库的解决方案。
alleni123
sqlmysql
从某网上爬了数千万的数据,存在文本中。
然后要导入mysql数据库。
悲剧的是数据库和我存数据的服务器不在一个内网里面。。
ping了一下, 19ms的延迟。
于是下面的代码是没用的。
ps = con.prepareStatement(sql);
ps.setString(1, info.getYear())............;
ps.exec
- JAVA IO InputStreamReader和OutputStreamReader
百合不是茶
JAVA.io操作 字符流
这是第三篇关于java.io的文章了,从开始对io的不了解-->熟悉--->模糊,是这几天来对文件操作中最大的感受,本来自己认为的熟悉了的,刚刚在回想起前面学的好像又不是很清晰了,模糊对我现在或许是最好的鼓励 我会更加的去学 加油!:
JAVA的API提供了另外一种数据保存途径,使用字符流来保存的,字符流只能保存字符形式的流
字节流和字符的难点:a,怎么将读到的数据
- MO、MT解读
bijian1013
GSM
MO= Mobile originate,上行,即用户上发给SP的信息。MT= Mobile Terminate,下行,即SP端下发给用户的信息;
上行:mo提交短信到短信中心下行:mt短信中心向特定的用户转发短信,你的短信是这样的,你所提交的短信,投递的地址是短信中心。短信中心收到你的短信后,存储转发,转发的时候就会根据你填写的接收方号码寻找路由,下发。在彩信领域是一样的道理。下行业务:由SP
- 五个JavaScript基础问题
bijian1013
JavaScriptcallapplythisHoisting
下面是五个关于前端相关的基础问题,但却很能体现JavaScript的基本功底。
问题1:Scope作用范围
考虑下面的代码:
(function() {
var a = b = 5;
})();
console.log(b);
什么会被打印在控制台上?
回答:
上面的代码会打印 5。
&nbs
- 【Thrift二】Thrift Hello World
bit1129
Hello world
本篇,不考虑细节问题和为什么,先照葫芦画瓢写一个Thrift版本的Hello World,了解Thrift RPC服务开发的基本流程
1. 在Intellij中创建一个Maven模块,加入对Thrift的依赖,同时还要加上slf4j依赖,如果不加slf4j依赖,在后面启动Thrift Server时会报错
<dependency>
- 【Avro一】Avro入门
bit1129
入门
本文的目的主要是总结下基于Avro Schema代码生成,然后进行序列化和反序列化开发的基本流程。需要指出的是,Avro并不要求一定得根据Schema文件生成代码,这对于动态类型语言很有用。
1. 添加Maven依赖
<?xml version="1.0" encoding="UTF-8"?>
<proj
- 安装nginx+ngx_lua支持WAF防护功能
ronin47
需要的软件:LuaJIT-2.0.0.tar.gz nginx-1.4.4.tar.gz &nb
- java-5.查找最小的K个元素-使用最大堆
bylijinnan
java
import java.util.Arrays;
import java.util.Random;
public class MinKElement {
/**
* 5.最小的K个元素
* I would like to use MaxHeap.
* using QuickSort is also OK
*/
public static void
- TCP的TIME-WAIT
bylijinnan
socket
原文连接:
http://vincent.bernat.im/en/blog/2014-tcp-time-wait-state-linux.html
以下为对原文的阅读笔记
说明:
主动关闭的一方称为local end,被动关闭的一方称为remote end
本地IP、本地端口、远端IP、远端端口这一“四元组”称为quadruplet,也称为socket
1、TIME_WA
- jquery ajax 序列化表单
coder_xpf
Jquery ajax 序列化
checkbox 如果不设定值,默认选中值为on;设定值之后,选中则为设定的值
<input type="checkbox" name="favor" id="favor" checked="checked"/>
$("#favor&quo
- Apache集群乱码和最高并发控制
cuisuqiang
apachetomcat并发集群乱码
都知道如果使用Http访问,那么在Connector中增加URIEncoding即可,其实使用AJP时也一样,增加useBodyEncodingForURI和URIEncoding即可。
最大连接数也是一样的,增加maxThreads属性即可,如下,配置如下:
<Connector maxThreads="300" port="8019" prot
- websocket
dalan_123
websocket
一、低延迟的客户端-服务器 和 服务器-客户端的连接
很多时候所谓的http的请求、响应的模式,都是客户端加载一个网页,直到用户在进行下一次点击的时候,什么都不会发生。并且所有的http的通信都是客户端控制的,这时候就需要用户的互动或定期轮训的,以便从服务器端加载新的数据。
通常采用的技术比如推送和comet(使用http长连接、无需安装浏览器安装插件的两种方式:基于ajax的长
- 菜鸟分析网络执法官
dcj3sjt126com
网络
最近在论坛上看到很多贴子在讨论网络执法官的问题。菜鸟我正好知道这回事情.人道"人之患好为人师" 手里忍不住,就写点东西吧. 我也很忙.又没有MM,又没有MONEY....晕倒有点跑题.
OK,闲话少说,切如正题. 要了解网络执法官的原理. 就要先了解局域网的通信的原理.
前面我们看到了.在以太网上传输的都是具有以太网头的数据包. 
- Android相对布局属性全集
dcj3sjt126com
android
RelativeLayout布局android:layout_marginTop="25dip" //顶部距离android:gravity="left" //空间布局位置android:layout_marginLeft="15dip //距离左边距
// 相对于给定ID控件android:layout_above 将该控件的底部置于给定ID的
- Tomcat内存设置详解
eksliang
jvmtomcattomcat内存设置
Java内存溢出详解
一、常见的Java内存溢出有以下三种:
1. java.lang.OutOfMemoryError: Java heap space ----JVM Heap(堆)溢出JVM在启动的时候会自动设置JVM Heap的值,其初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)不可超过物理内存。
可以利用JVM提
- Java6 JVM参数选项
greatwqs
javaHotSpotjvmjvm参数JVM Options
Java 6 JVM参数选项大全(中文版)
作者:Ken Wu
Email:
[email protected]
转载本文档请注明原文链接 http://kenwublog.com/docs/java6-jvm-options-chinese-edition.htm!
本文是基于最新的SUN官方文档Java SE 6 Hotspot VM Opt
- weblogic创建JMC
i5land
weblogicjms
进入 weblogic控制太
1.创建持久化存储
--Services--Persistant Stores--new--Create FileStores--name随便起--target默认--Directory写入在本机建立的文件夹的路径--ok
2.创建JMS服务器
--Services--Messaging--JMS Servers--new--name随便起--Pers
- 基于 DHT 网络的磁力链接和BT种子的搜索引擎架构
justjavac
DHT
上周开发了一个磁力链接和 BT 种子的搜索引擎 {Magnet & Torrent},本文简单介绍一下主要的系统功能和用到的技术。
系统包括几个独立的部分:
使用 Python 的 Scrapy 框架开发的网络爬虫,用来爬取磁力链接和种子;
使用 PHP CI 框架开发的简易网站;
搜索引擎目前直接使用的 MySQL,将来可以考虑使
- sql添加、删除表中的列
macroli
sql
添加没有默认值:alter table Test add BazaarType char(1)
有默认值的添加列:alter table Test add BazaarType char(1) default(0)
删除没有默认值的列:alter table Test drop COLUMN BazaarType
删除有默认值的列:先删除约束(默认值)alter table Test DRO
- PHP中二维数组的排序方法
abc123456789cba
排序二维数组PHP
<?php/*** @package BugFree* @version $Id: FunctionsMain.inc.php,v 1.32 2005/09/24 11:38:37 wwccss Exp $*** Sort an two-dimension array by some level
- hive优化之------控制hive任务中的map数和reduce数
superlxw1234
hivehive优化
一、 控制hive任务中的map数: 1. 通常情况下,作业会通过input的目录产生一个或者多个map任务。 主要的决定因素有: input的文件总个数,input的文件大小,集群设置的文件块大小(目前为128M, 可在hive中通过set dfs.block.size;命令查看到,该参数不能自定义修改);2. 
- Spring Boot 1.2.4 发布
wiselyman
spring boot
Spring Boot 1.2.4已于6.4日发布,repo.spring.io and Maven Central可以下载(推荐使用maven或者gradle构建下载)。
这是一个维护版本,包含了一些修复small number of fixes,建议所有的用户升级。
Spring Boot 1.3的第一个里程碑版本将在几天后发布,包含许多