实时搜索: ios dealloc是谁的方法

ios dealloc是谁的方法

984条评论 1310人喜欢 4516次阅读 671人点赞
...

ios中weak属性需要在dealloc里面置为nil吗:

arc里面的dealloc方法和mrc手动内存管理的区别在于。arc里面不能调用super方法。arc里面的dealloc一般用来注销NSNotification或者timer之类的实例。如果是类里面的强引用,可以在didReceiveMemoryWarning置于nil,如楼上所说,确实arc的内存销毁有滞后性,但是从性能上来说arc更优。

arc也是可以通过类方法创建实例的。

ios 什么时候调用dealloc: arc面deallocmrc手内存管理区别于arc面能调用superarc面dealloc般用注销NSNotification或者timer类实例类面强引用didReceiveMemoryWarning置于nil楼所说确实arc内存销毁滞性性能说arc更优arc通类创建实例

ios swift app main函数在哪: ios怎么查看内存泄露,有以下几种方法供大家参考: 1.静态分析 通过静态分析我们可以最初步的了解到代码的一些不规范的地方或者是存在的内存泄漏,这是我们第一步对内存泄漏的检测。当然有一些警告并不是我们关心的可以略过。 2.通过instruments来检查内存泄漏 这个方法能粗略的定位我们在哪里发生了内存泄漏。方法是完成一个循环操作,如果内存增长为0就证明我们程序在该次循环操作中不存在内存泄漏,如果内存增长不为0那证明有可能存在内存泄漏,当然具体问题需要具体分析。 3.代码测试内存泄漏 在做这项工作之前我们要注意一下,在dealloc的方法中我们是否已经释放了该对象所拥有的所有对象。观察对象的生成和销毁是否配对。准确的说就是init(创建对象的方法)和dealloc是否会被成对触发(简单说来就是走一次创建对象就有走一次dealloc该对象)。 下面是自己遇到的一些比较隐秘的造成内存泄漏的情况: 1.两个对象互相拥有:也就是说对象a里面retain/addSubview了b对象,b对象同时也retain/addSubView了a对象。注意:delegate不要用retain属性,要用assign属性也会导致互相拥有。 2.有时候需要用removeFromSuperView来释放:具体说明,也许我的a对象拥有一个b对象,b对象add到了c对象上,而在我们的设计中b对象的生命周期应该和a对象相同;这时候只一句[b release]/self.b = nil是不能把b对象释放掉的(一般情况下release会使其retainCount-1,[super dealloc]会再次将所有subView的retainCount-1,而b并不是a的subView,所有最后的一次-1没有了);所以我们需要在之前加上[b removeFromSuperView]。

iOS条件编译之判断当前编译环境是不是arc: 一开始我觉得ARC真他X是个好到爆的东西,因为本人从C++年代就特别不喜欢做dealloc之类的事情,导致在刚开始进行iOS开发的时候常年因为各种忘记写release导致程序崩溃……当时为了这个,我甚至潜行研究xcode内置的脚本功能,希望能代替我自动写release……现在想起来当时真是懒到爆……不过在正式使用ARC之后,各种各样的问题就出现了……首先,和非ARC代码混用问题。前段时间我在写一个微博客户端,写道某个阶段的时候,突然发现底层实现不能出现了不能预测的崩溃,经过几个晚上的通宵研究之后,我发现那就是傻叉ARC和非ARC代码混用问题。网上很多人说对于非ARC代码,只需要在编的时候加上那啥-FOBJ-ARC啥的就好了,实际上不是的!因为加上这个代码之后,一旦你的程序中有ARC和非ARC这两个CLASS之间交互的时候,就会莫名的出现内存泄露!而且泄漏得莫名其妙……最终解决方案只能重写其中一个class以保证两者均为ARC或者非ARC……然后,我要说一下那个该死的_weak……这货,说实在话,我已经用了很长一段时间了,不过还是比较不放心……不,非常不放心才对。最主要原因是:这货的release位置不可判断……不知道是不是因为我程序function太多的原因,根据监测,那个class里面的一个weakA的消灭位置是不定的……在我读懂苹果官方文档之前,我只能把那货给列为一个不确定变量了……现在为了程序稳定暂时用以个永远不释放的strongA来做的处理……说实在……真有那么一瞬间……就那一瞬间……我好怀念没有ARC的年代……最后关于内存泄露,这个我只能呵呵了,我这边某个程序,在uiviewclass下面添加一个uiscrollview和一个uiimageview之后必定会出现各种内存溢出……至今不理解为啥会这样……哪怕两个变量里面都是空,还是会报内存不足……这个项目还有一周交工,所以我……非常紧张……===========体内酒精含量:0.4%===========上面说了很多,大部分都是废话……给自己跪一个,然后码代码去……===========走之前===========狼大人你作为iOS开发专业人士不给个答案么?

ios 内存泄露会导致什么问题: ios怎么查看内存泄露,有以下几种方法供大家参考: 1.静态分析 通过静态分析可以最初步的了解到代码的一些不规范的地方或者是存在的内存泄漏,这是第一步对内存泄漏的检测。当然有一些警告并不是关心的可以略过。 2.通过instruments来检查内存泄漏 这个方法能粗略的定位在哪里发生了内存泄漏。方法是完成一个循环操作,如果内存增长为0就证明程序在该次循环操作中不存在内存泄漏,如果内存增长不为0那证明有可能存在内存泄漏,当然具体问题需要具体分析。 3.代码测试内存泄漏 在做这项工作之前要注意一下,在dealloc的方法中是否已经释放了该对象所拥有的所有对象。观察对象的生成和销毁是否配对。准确的说就是init(创建对象的方法)和dealloc是否会被成对触发(简单说来就是走一次创建对象就有走一次dealloc该对象)。 下面是遇到的一些比较隐秘的造成内存泄漏的情况: 1.两个对象互相拥有:也就是说对象a里面retain/addSubview了b对象,b对象同时也retain/addSubView了a对象。注意:delegate不要用retain属性,要用assign属性也会导致互相拥有。 2.有时候需要用removeFromSuperView来释放:具体说明,也许a对象拥有一个b对象,b对象add到了c对象上,而在设计中b对象的生命周期应该和a对象相同;这时候只一句[b release]/self.b = nil是不能把b对象释放掉的(一般情况下release会使其retainCount-1,[super dealloc]会再次将所有subView的retainCount-1,而b并不是a的subView,所有最后的一次-1没有了);所以需要在之前加上[b removeFromSuperView]。

ios开发 self.navigationcontroller dismissviewcontrolleranimated 子控制器没有: 本文我们来分享在ios开发中如何通过自定义按钮并跳转到另外一个视图的学习实例,这种场景在ios开发中很常用。 刚学iOS不久,虽然视图切换能直接用stroryboard创建,拖根线就完事了!但不知道为嘛,还是感觉iOS开发中代码控制视图灵活方便。 不多说了,开始今天的笔记: 新建工程,不多说啦!我喜欢用Empty Application,创建完成后,新建两个UIViewController类,假设A和B吧!!哈哈 这儿将appDelegate中的代码就省了!!哈哈。相信能看到这儿的人,也懂得如何设置root视图了 我们要实现的是,从A点击一个按钮,弹出来B窗口,然后点击B窗口的一个按钮,返回到A窗口。 直接开始代码: A: - (void)viewDidLoad { [super viewDidLoad]; //设置视图背景颜色 self.view.backgroundColor = [UIColor groupTableViewBackgroundColor]; //添加弹出模态视图按钮 UIButton * button = [UIButton buttonWithType:UIButtonTypeRoundedRect]; //设置按钮位置和大小 [button setFrame:CGRectMake(120, 220, 80, 40)]; //设置按钮文字及状态 [button setTitle:@"模态视图" forState:UIControlStateNormal]; //添加动作绑定 [button addTarget:self action:@selector(modelViewGO) forControlEvents:UIControlEventTouchUpInside]; //添加进视图 [self.view addSubview:button]; } -(void) modelViewGO { BViewController * modalView = [[BViewController alloc]init]; modalView.modalTransitionStyle = UIModalTransitionStyleCoverVertical; [self presentViewController:modalView animated:YES completion:nil]; // [modalView release]; } 然后在B视图中,添加返回按钮及相关代码: B: - (void)viewDidLoad { //和A视图差不多的东西,不解释啦!! [super viewDidLoad]; self.view.backgroundColor = [UIColor purpleColor]; UIButton * button = [UIButton buttonWithType:UIButtonTypeRoundedRect]; [button setFrame:CGRectMake(130, 50, 60, 20)]; [button setTitle:@"返回" forState:UIControlStateNormal]; [button addTarget:self action:@selector(back ) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:button]; } -(void)back { //下面这行代码作用就是将弹出的模态视图移除,第一个yes表示移除的时候有动画效果,第二参数是设置一个回调,当模态视图移除消失后,会回到这里,可以在这里随便写句话打个断点,试一下就知道确实会回调到这个方法 // [self dismissViewControllerAnimated:YES completion:nil]; 或带有回调的如下方法 [self dismissViewControllerAnimated:YES completion:^{ NSLog(@"back");//这里打个断点,点击按钮模态视图移除后会回到这里 //ios 5.0以上可以用该方法 }]; } 程序默认的动画效果是从下往上弹出,可以改modalTransitionStyle换成其他效果 modalView.modalTransitionStyle = UIModalTransitionStyleCoverVertical; typedef NS_ENUM(NSInteger, UIModalTransitionStyle) { UIModalTransitionStyleCoverVertical = 0,//默认垂直向上 UIModalTransitionStyleFlipHorizontal, 翻转效果 UIModalTransitionStyleCrossDissolve,淡入淡出 #if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_3_2 UIModalTransitionStylePartialCurl,翻页效果 #endif }; 需要注意的地方 :1.在弹出的模态视图上点击返回按钮后,该视图对象彻底被释放了,记得要将添加到该视图上的一些对象都写在dealloc方法中

ios nsuserdefaults怎么覆盖: NSUserDefaults适合存储轻量级的本地数据,比如要保存一个登陆界面的数据,用户名、密码之类的,个人觉得使用NSUserDefaults是首选。下次再登陆的时候就可以直接从NSUserDefaults里面读取上次登陆的信息咯。
因为如果使用自己建立的plist文件什么的,还得自己显示创建文件,读取文件,很麻烦,而是用NSUserDefaults则不用管这些东西,就像读字符串一样,直接读取就可以了。
NSUserDefaults支持的数据格式有:NSNumber(Integer、Float、Double),NSString,NSDate,NSArray,NSDictionary,BOOL类型。很实用吧
NSUserDefaults很方便,读取也很容易。下面给出一个示例看看如何使用:(PS:更详细的也可以参考官方文档哈)
ViewController.h文件中主要是放几个控件,用于显示存储的数据:

[cpp] view plain copy
#import <UIKit/UIKit.h>

@interface ViewController : UIViewController
{

IBOutlet UILabel *txtInteger;
IBOutlet UILabel *txtFloat;
IBOutlet UILabel *txtDouble;
IBOutlet UILabel *txtNSString;
IBOutlet UILabel *txtNSDate;
IBOutlet UILabel *txtNSArray;
IBOutlet UILabel *txtNSDictionary;
}

@end
ViewController.m文件中最重要的是两个方法:

saveNSUserDefaults:用于将各种类型数据保存到NSUserDefaults中

readNSUserDefautls:用于从NSUserDefaults中读取各种类型的数据。在viewDidLoad中调用这两个方法就可以看出结果咯

[cpp] view plain copy
#import "ViewController.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad
{
[super viewDidLoad];

[self saveNSUserDefaults]; //调用此方法将各种数据存储到NSUserDefautls中,在下面定义
[self readNSUserDefaults]; //调用此方法从NSUserDefautls中读取各种数据,在下面定义
}

- (void)viewDidUnload
{
[txtNSString release];
txtNSString = nil;
[txtNSDate release];
txtNSDate = nil;
[txtNSArray release];
txtNSArray = nil;
[txtNSDictionary release];
txtNSDictionary = nil;
[txtInteger release];
txtInteger = nil;
[txtFloat release];
txtFloat = nil;
[txtDouble release];
txtDouble = nil;
[super viewDidUnload];
// Release any retained subviews of the main view.
}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
return (interfaceOrientation != UIInterfaceOrientationPortraitUpsideDown);
}

- (void)dealloc {
[txtNSString release];
[txtNSDate release];
[txtNSArray release];
[txtNSDictionary release];
[txtInteger release];
[txtFloat release];
[txtDouble release];
[super dealloc];
}

//保存数据到NSUserDefaults
-(void)saveNSUserDefaults
{
NSString *myString = @"enuola";
int myInteger = 100;
float myFloat = 50.0f;
double myDouble = 20.0;
NSDate *myDate = [NSDate date];
NSArray *myArray = [NSArray arrayWithObjects:@"hello", @"world", nil];
NSDictionary *myDictionary = [NSDictionary dictionaryWithObjects:[NSArray arrayWithObjects:@"enuo", @"20", nil] forKeys:[NSArray arrayWithObjects:@"name", @"age", nil]];

//将上述数据全部存储到NSUserDefaults中
NSUserDefaults *userDefaults = [NSUserDefaults standardUserDefaults];
//存储时,除NSNumber类型使用对应的类型意外,其他的都是使用setObject:forKey:
[userDefaults setInteger:myInteger forKey:@"myInteger"];
[userDefaults setFloat:myFloat forKey:@"myFloat"];
[userDefaults setDouble:myDouble forKey:@"myDouble"];

[userDefaults setObject:myString forKey:@"myString"];
[userDefaults setObject:myDate forKey:@"myDate"];
[userDefaults setObject:myArray forKey:@"myArray"];
[userDefaults setObject:myDictionary forKey:@"myDictionary"];

//这里建议同步存储到磁盘中,但是不是必须的
[userDefaults synchronize];

}

//从NSUserDefaults中读取数据
-(void)readNSUserDefaults
{
NSUserDefaults *userDefaultes = [NSUserDefaults standardUserDefaults];

//读取数据到各个label中
//读取整型int类型的数据
NSInteger myInteger = [userDefaultes integerForKey:@"myInteger"];
txtInteger.text = [NSString stringWithFormat:@"%d",myInteger];

//读取浮点型float类型的数据
float myFloat = [userDefaultes floatForKey:@"myFloat"];
txtFloat.text = [NSString stringWithFormat:@"%f",myFloat];

//读取double类型的数据
double myDouble = [userDefaultes doubleForKey:@"myDouble"];
txtDouble.text = [NSString stringWithFormat:@"%f",myDouble];

//读取NSString类型的数据
NSString *myString = [userDefaultes stringForKey:@"myString"];
txtNSString.text = myString;

//读取NSDate日期类型的数据
NSDate *myDate = [userDefaultes valueForKey:@"myDate"];
NSDateFormatter *df = [[NSDateFormatter alloc] init];
[df setDateFormat:@"yyyy-MM-dd HH:mm:ss"];
txtNSDate.text = [NSString stringWithFormat:@"%@",[df stringFromDate:myDate]];

//读取数组NSArray类型的数据
NSArray *myArray = [userDefaultes arrayForKey:@"myArray"];
NSString *myArrayString = [[NSString alloc] init];
for(NSString *str in myArray)
{
NSLog(@"str= %@",str);
myArrayString = [NSString stringWithFormat:@"%@ %@", myArrayString, str];
[myArrayString stringByAppendingString:str];
// [myArrayString stringByAppendingFormat:@"%@",str];
NSLog(@"myArrayString=%@",myArrayString);
}
txtNSArray.text = myArrayString;

//读取字典类型NSDictionary类型的数据
NSDictionary *myDictionary = [userDefaultes dictionaryForKey:@"myDictionary"];
NSString *myDicString = [NSString stringWithFormat:@"name:%@, age:%d",[myDictionary valueForKey:@"name"], [[myDictionary valueForKey:@"age"] integerValue]];
txtNSDictionary.text = myDicString;
}

@end

好了,运行一下,可以看到xib文件中的各种数据已经绑定上了吧?

再次运行的时候,可以把viewDidLoad中的 [self saveNSUserDefaults]; 这一行注释掉,让程序直接读取而不存储数据,发现以前保存的数据仍然可以读取到界面上。

ios通知和kov的区别用法: iOS 中KVC、KVO、NSNotification、delegate 总结及区别

1、KVC,即是指 NSKeyValueCoding,一个非正式的Protocol,提供一种机制来间接访问对象的属性。而不是通过调用Setter、Getter方法访问。KVO 就是基于 KVC 实现的关键技术之一。
Demo:
@interface myPerson : NSObject
{
NSString*_name;
int _age;
int _height;
int _weight;
} @end

@interface testViewController :UIViewController

@property (nonatomic, retain) myPerson*testPerson;

@end

- (void)testKVC
{
testPerson = [[myPerson alloc] init];
NSLog(@"testPerson‘s init height =%@", [testPerson valueForKey:@"height"]);
[testPerson setValue:[NSNumber numberWithInt:168]forKey:@"height"]; NSLog(@"testPerson‘s height = %@", [testPerson valueForKey:@"height"]);
}
第一段代码是定义了一个myPerson的类,这个类有一个_height的属性,但是没有提供任何getter/setter的访问方法。同时在testViewController这个类里面有一个myPerson的对象指针。
当myPerson实例化后,常规来说是无法访问这个对象的_height属性的,不过通过KVC我们做到了,代码就是testKVC这个函数。
运行之后打印值就是:
2015-3-13 11:16:21.970 test[408:c07] testPerson‘s init height = 0
2015-3-13 11:16:21.971 test[408:c07] testPerson‘s height = 168
这就说明确实读写了_height属性。

KVC的常用方法:
- (id)valueForKey:(NSString *)key; -(void)setValue:(id)value forKey:(NSString *)key;
valueForKey的方法根据key的值读取对象的属性,setValue:forKey:是根据key的值来写对象的属性。
注意:
(1). key的值必须正确,如果拼写错误,会出现异常
(2). 当key的值是没有定义的,valueForUndefinedKey:这个方法会被调用,如果你自己写了这个方法,key的值出错就会调用到这里来
(3). 因为类key反复嵌套,所以有个keyPath的概念,keyPath就是用.号来把一个一个key链接起来,这样就可以根据这个路径访问下去
(4). NSArray/NSSet等都支持KVC

2、KVO的是KeyValue Observe的缩写,中文是键值观察。这是一个典型的观察者模式,观察者在键值改变时会得到通知。iOS中有个Notification的机制,也可以获得通知,但这个机制需要有个Center,相比之下KVO更加简洁而直接。

KVO的使用也很简单,就是简单的3步。
1.注册需要观察的对象的属性addObserver:forKeyPath:options:context:
2.实现observeValueForKeyPath:ofObject:change:context:方法,这个方法当观察的属性变化时会自动调用
3.取消注册观察removeObserver:forKeyPath:context:
Demo:
@interface myPerson : NSObject
{
NSString *_name;
int _age;
int _height;
int _weight;
}
@end

@interface testViewController : UIViewController
@property (nonatomic, retain) myPerson *testPerson;

- (IBAction)onBtnTest:(id)sender;
@end

- (void)testKVO
{
testPerson = [[myPerson alloc] init];

[testPerson addObserver:self forKeyPath:@"height" options:NSKeyValueObservingOptionNew context:nil];
}

- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context
{
if ([keyPath isEqualToString:@"height"]) {
NSLog(@"Height is changed! new=%@", [change valueForKey:NSKeyValueChangeNewKey]);
} else {
[super observeValueForKeyPath:keyPath ofObject:object change:change context:context];
}
}

- (IBAction)onBtnTest:(id)sender {
int h = [[testPerson valueForKey:@"height"] intValue];
[testPerson setValue:[NSNumber numberWithInt:h+1] forKey:@"height"];
NSLog(@"person height=%@", [testPerson valueForKey:@"height"]);
}

- (void)dealloc
{
[testPerson removeObserver:self forKeyPath:@"height" context:nil];
[super dealloc];
}
第一段代码声明了myPerson类,里面有个_height的属性。在testViewController有一个testPerson的对象指针。
在testKVO这个方法里面,我们注册了testPerson这个对象height属性的观察,这样当testPerson的height属性变化时, 会得到通知。在这个方法中还通过NSKeyValueObservingOptionNew这个参数要求把新值在dictionary中传递过来。
重写了observeValueForKeyPath:ofObject:change:context:方法,这个方法里的change这个NSDictionary对象包含了相应的值。
需要强调的是KVO的回调要被调用,属性必须是通过KVC的方法来修改的,如果是调用类的其他方法来修改属性,这个观察者是不会得到通知的。

3、NSNotification的用法见http://blog.csdn.net/eduora_meimei/article/details/44198909

区别:
delegate 的 优势 :
1.非常严格的语法。所有将听到的事件必须是在delegate协议中有清晰的定义。
2.如果delegate中的一个方法没有实现那么就会出现编译警告/错误
3.协议必须在controller的作用域范围内定义
4.在一个应用中的控制流程是可跟踪的并且是可识别的;
5.在一个控制器中可以定义定义多个不同的协议,每个协议有不同的delegates
6.没有第三方对象要求保持/监视通信过程。
7.能够接收调用的协议方法的返回值。这意味着delegate能够提供反馈信息给controller
缺点 :
1.需要定义很多代码:1.协议定义;2.controller的delegate属性;3.在delegate本身中实现delegate方法定义
2.在释放代理对象时,需要小心的将delegate改为nil。一旦设定失败,那么调用释放对象的方法将会出现内存crash
3.在一个controller中有多个delegate对象,并且delegate是遵守同一个协议,但还是很难告诉多个对象同一个事件,不过有可能。
notification的 优势 :
1.不需要编写多少代码,实现比较简单;
2.对于一个发出的通知,多个对象能够做出反应,即1对多的方式实现简单
3.controller能够传递context对象(dictionary),context对象携带了关于发送通知的自定义的信息
缺点 :
1.在编译期不会检查通知是否能够被观察者正确的处理;
2.在释放注册的对象时,需要在通知中心取消注册;
3.在调试的时候应用的工作以及控制过程难跟踪;
4.需要第三方对喜爱那个来管理controller与观察者对象之间的联系;
5.controller和观察者需要提前知道通知名称、UserInfodictionary keys。如果这些没有在工作区间定义,那么会出现不同步的情况;
6.通知发出后,controller不能从观察者获得任何的反馈信息。
KVO的 优势 :
1.能够提供一种简单的方法实现两个对象间的同步。例如:model和view之间同步;
2.能够对非我们创建的对象,即内部对象的状态改变作出响应,而且不需要改变内部对象(SKD对象)的实现;
3.能够提供观察的属性的最新值以及先前值;
4.用key paths来观察属性,因此也可以观察嵌套对象;
5.完成了对观察对象的抽象,因为不需要额外的代码来允许观察值能够被观察
缺点 :
1.我们观察的属性必须使用strings来定义。因此在编译器不会出现警告以及检查;
2.对属性重构将导致我们的观察代码不再可用;
3.复杂的“IF”语句要求对象正在观察多个值。这是因为所有的观察代码通过一个方法来指向;
4.当释放观察者时不需要移除观察者。
1. 效率肯定是delegate比NSNotification高。
delegate方法比notification更加直接,最典型的特征是,delegate方法往往需要关注返回值,也就是delegate方法的结果。比如-windowShouldClose:,需要关心返回的是yes还是no。所以delegate方法往往包含 should这个很传神的词。也就是好比你做我的delegate,我会问你我想关闭窗口你愿意吗?你需要给我一个答案,我根据你的答案来决定如何做下一步。相反的,notification最大的特色就是不关心接受者的态度,我只管把通告放出来,你接受不接受就是你的事情,同时我也不关心结果。所以notification往往用did这个词汇,比如NSWindowDidResizeNotification,那么NSWindow对象放出这个notification后就什么都不管了也不会等待接 受者的反应。
2、KVO和NSNotification的区别:
和delegate一样,KVO和NSNotification的作用也是类与类之间的通信,与delegate不同的是1)这两个都是负责发出通知,剩下的事情就不管了,所以没有返回值;2)delegate只是一对一,而这两个可以一对多。这两者也有各自的特点。
转载地址:http://www.mamicode.com/info-detail-515516.html

  • 210质因数有哪些

    宙和宇组词有哪些: 宇宙、 层宙、 宙外、 世宙、 宙始、 上宙、 宙合、 浃宙、 紫宙、 穷宙、 宇宙观、 宇宙飞船、 宇宙空间、 宇宙速度、 宇宙火箭、 宇宙通宇航、宇航员、屋宇、琼楼玉宇、环宇、玉宇、气宇轩昂、神宇、庙宇、宇宙通信...

    702条评论 6115人喜欢 3544次阅读 294人点赞
  • ml是什么意思啊

    2017款蒙迪欧1.5T显示动力总成故障?: 需要检查一下发动机,有可能是发动机排放或是有传感器工作不正常 ...

    586条评论 2845人喜欢 6454次阅读 506人点赞
  • dw怎么样

    哪里有NAVI战队的衣服卖: NAVI官网,或者找圈里的人,淘宝的百分之八十都是高仿 ...

    347条评论 4253人喜欢 4952次阅读 224人点赞
  • 2017年是第几个高考

    鬼怪imissyou百度云: 鬼怪 OST Part 7昭宥--I MISS YOU mp3百度云下载网址:http://pan.baidu.com/s/1dEZtSyt 满意的话记得采纳谢谢~ ...

    519条评论 5265人喜欢 5320次阅读 361人点赞
  • 2016年中国M2有多少

    NB有这款鞋吗?480能买到吗?: 型号580,绝提什么忘了,一两年前的联名款。应该2000+才能收到,480的话莆田(假)倒是一大堆 ...

    343条评论 3452人喜欢 3675次阅读 719人点赞
  • 五台县在哪

    2017款新蒙迪欧可以改成后电动后备箱。有没有什么影响?: 没有什么影响的 ...

    823条评论 5583人喜欢 1759次阅读 430人点赞
  • ps4 r3是哪个键

    csgo navi里navi战队都用什么鼠标: 其实没必要跟着别人用的鼠标的,适合自己手感的才是最重要,特别是玩游戏,他们都是有自己的手感鼠标,如果要买的话可以推荐几款游戏鼠标给楼主试试,雷蛇炼狱蝰蛇、RAPOO V26、罗技G300S等等都还不错,适当调节dpi...

    911条评论 2651人喜欢 6058次阅读 284人点赞