前言
1.既然有问题我们该怎样解决 ?
-
Google 简单来说比百度搜索的答案相对要多,要更准确效率更高, 建议使用英文搜索
-
Stack Overflow 一个与程序相关的IT技术问答网站, 简单来说工作中的70%问题在这里都能解决
搜索是解决问题的一种办法, 那么剩余30%的问题还是需要自己独立去解决, 那么有人会问有没有能提高独立解决问题的办法呢 ? 比如: 积累所遇到的崩溃信息, 学会查看崩溃信息, 查看官方文档的技巧等等) 本文暂时不会详解, 有时间的话需要单独写一篇文章来探究如何高效的解决崩溃问题!
-
(1)如果当前断点指向内存, 那么就是初始化时分配内存时有问题
-
(2)添加全局断点的问题:
崩溃断点.png
-
保留2位小数点
//.2代表小数点后面保留2位(2代表保留的数量)
NSString*string = [NSStringstringWithFormat:@"%.2f",M_PI];
//输出结果是: 3.14
NSLog(@"%@", string);
-
用0补全的方法
NSIntegercount = 5;
//02代表:如果count不足2位用0在最前面补全(2代表总输出的个数)
NSString*string = [NSStringstringWithFormat:@"%02zd",count];
//输出结果是: 05
NSLog(@"%@", string);
-
字符串中有特殊符号%怎么办
NSIntegercount = 50;
//%是一个特殊符号如果在NSString中用到%需要如下写法
NSString*string = [NSStringstringWithFormat:@"%zd%%",count];
//输出结果是: 50%
NSLog(@"%@",string);
-
字符串中有特殊符号"怎么办
NSIntegercount = 50;
//"是一个特殊符号,如果在NSString中用到"需要用\进行转义
NSString*string = [NSStringstringWithFormat:@"%zd\"",count];
//输出结果是: 50"
NSLog(@"%@",string);
首先我们先想想如果是你, 你会怎么去判断一个从网络获取的图片URL是否为gif图片, 是否是这样呢 ? 如下:
//假设这是一个网络获取的URL
NSString *path =@"http://pic3.nipic.com/20090709/2893198_075124038_2.gif";
// 判断是否为gif
NSString *extensionName = path.pathExtension;
if([extensionName.lowercaseStringisEqualToString:@"gif"]){
//是gif图片
}else {
//不是gif图片
}
以上判断看似是可以的,但是这不严谨的, 在不知道图片扩展名的情况下, 如何知道图片的真实类型 ? 其实就是取出图片数据的第一个字节, 就可以判断出图片的真实类型那该怎么做呢如下:
//通过图片Data数据第一个字节来获取图片扩展名
-(NSString *)contentTypeForImageData:(NSData*)data{
uint8_tc;
[datagetBytes:&clength:1];
switch(c){
case0xFF:
return@"jpeg";
case0x89:
return@"png";
case0x47:
return@"gif";
case0x49:
case0x4D:
return@"tiff";
case0x52:
if([datalength]<12){
returnnil;
}
NSString*testString = [[NSString alloc]initWithData:[datasubdataWithRange:NSMakeRange(0,12)]encoding:NSASCIIStringEncoding];
if([testStringhasPrefix:@"RIFF"]&& [testStringhasSuffix:@"WEBP"]){
return@"webp";
}
returnnil;
}
returnnil;
}
其实图片数据的第一个字节是固定的,一种类型的图片第一个字节就是它的标识, 我们来调用一下这个方法:
//假设这是一个网络获取的URL
NSString*path =@"http://pic.rpgsky.net/images/2016/07/26/3508cde5f0d29243c7d2ecbd6b9a30f1.png";
NSData*data = [NSData dataWithContentsOfURL:[NSURLURLWithString:path]];
//调用获取图片扩展名
NSString*string = [self contentTypeForImageData:data];
//输出结果为 png
NSLog(@"%@",string);
5.Button禁止触摸事件的2种方式
大家应该知道, 有很多需求是在规定内不允许点击Button, 并且让用户知道这个按钮是不可以点击的,那我们应该这样设置:
//会改变按钮的状态,颜色会变灰
button.enabled= NO;
但是又有一个需求是既不能点击也不要改变Button颜色:
//保持按钮原来的状态,颜色不会变
button.userInteractionEnabled= NO;
6.跟xib一起走过的坑
(1) 如果在xib中有一个控件, 已经明确设置尺寸了,输出的frame也是对的, 但是显示出来的效果不一样(比如尺寸变大了), 如果是这种情况一般就是autoresizingMask自动伸缩属性在搞鬼! 解决办法如下:
//xib的awakeFromNib方法中设置UIViewAutoresizingNone进行清空
-(void)awakeFromNib{
self.autoresizingMask= UIViewAutoresizingNone;
}
(2)如果你的控制器的view是用xib创建的, 当你拿到view的尺寸是不准确的, 在这里我们就需要通过[UIScreen mainScreen].bounds拿到尺寸, 但是storyboard的尺寸是准确的!
7.你是用什么方法设置图片圆角?
首先你是否是这么设置的:
//cornerRadius 设置为self.iconImage图片宽度的一半(圆形图片)
self.iconImage.layer.cornerRadius=20;
self.iconImage.layer.masksToBounds=YES;
在此之后建议大家尽量不要这么设置, 因为使用图层过量会有卡顿现象, 特别是弄圆角或者阴影会很卡, 如果设置图片圆角我们一般用绘图来做:
/** 设置圆形图片(放到分类中使用) */
-(UIImage *)cutCircleImage{
UIGraphicsBeginImageContextWithOptions(self.size,NO,0.0);
// 获取上下文
CGContextRefctr = UIGraphicsGetCurrentContext();
// 设置圆形
CGRectrect = CGRectMake(0,0,self.size.width,self.size.height);
CGContextAddEllipseInRect(ctr,rect);
// 裁剪
CGContextClip(ctr);
// 将图片画上去
[selfdrawInRect:rect];
UIImage*image = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
returnimage;
}
这个方法就是设置圆角图片, 效率很高, 不会造成卡顿现象, 大家要把这个方法单独放到分类中使用
8. ## 与 @# 在宏里面该怎样使用
-
##的使用, 首先我们添加一个宏
#define LRWeakSelf(type) __weak typeof(type) weak##type = type;
-
#的意思是紧跟着它的后面的标识符添加一个双引号""
-
@#的使用, 我们添加一个普通的宏:
//随便写一个宏
#define LRToast(str) [NSString stringWithFormat:@"%@",str]
//这个宏需要这样写
LRToast(@"温馨提示");
NSLog(@"%@",LRToast(@"温馨提示"));
强调下我只是随便定义一个宏来做示例, 以上代码是正常的使用,我们在来看看添加@#是怎么使用的:
//随便写一个宏
#define LRToast(str) [NSString stringWithFormat:@"%@",@#str]
//这个宏需要这样写
LRToast(温馨提示);
//正常运行,打印不会报错
NSLog(@"%@",LRToast(温馨提示));
按照如上图从上到下顺序读就是当前这条约束的状态
First Item(登录按钮的顶部)Relation(等于) Second Item(父类View的顶部) Constant(加上 10) Multiplier(乘以 1)
在iOS中简单的版本号是怎样管理的呢? 首先我们的App第一版本首次上线, 比如以1.0.0为首次上线的版本号: