摘要:
这里用一个简单的宏来演示: #define SAFE_DELETE(p) do{ delete p; p = NULL} while(0) 假设这里去掉do...while(0), #define SAFE_DELETE(p) delete p; p = NULL; 那么以下代码: if(NULL 阅读全文
摘要:
#a会创建一个字符串:"a";a##b会创建一个新的token:ab。 #include <stdio.h> #define f(a,b) a##b #define g(a) #a #define h(a) g(a) int main() { printf("%s\n",h(f(1,2))); pr 阅读全文
摘要:
PForDelta算法 原理 PForDelta算法最早由Heman在2005年提出,它允许同时对整个chunk数据(例128个数)进行压缩处理。基础思想是对于一个chunk的数列(例128个),认为其中占多数的x%数据(例90%)占用较小空间,而剩余的少数1-x%(例10%)才是导致数字存储空间过 阅读全文
摘要:
1.图形化 偏差:描述的是预测值(估计值)的期望与真实值之间的差距。偏差越大,越偏离真实数据,如下图第二行所示。 方差:描述的是预测值的变化范围,离散程度,也就是离其期望值的距离。方差越大,数据的分布越分散,如下图右列所示。 2.公式 以回归任务为例,学习算法的期望预测为: 这里的期望预测也就是针对 阅读全文
摘要:
对应示例代码,回调函数不会阻塞 import time from concurrent.futures import ThreadPoolExecutor def get(delay): print('delay {}s'.format(delay)) time.sleep(delay) # 延时 阅读全文
摘要:
一、简介 常用的有如下几种方式 synchronized(this)、synchronized(Object)与synchronized修饰静态方法、synchronized(class) 二、修饰本身对象 如下两种写法是具有一样的效果,都是锁住自己本身的对象,当同一对象多次调用时,同步锁会起作用。 阅读全文
摘要:
产生异常,首先会生成异常对象。 如果在try语句块中的任何代码抛出了一个在catch子句中说明的异常类,那么 1)程序将跳过try语句块的其它代码 2)程序将执行catch子句中的处理器代码 如果在try语句块中没有抛出任何异常,那么程序将跳过catch子句。 如果方法中的任何代码抛出了一个在cat 阅读全文
摘要:
一、函数装饰器 1.从函数中返回函数 在 if/else 语句中我们返回 greet 和 welcome,而不是 greet() 和 welcome()。为什么那样?这是因为当你把一对小括号放在后面,这个函数就会执行;然而如果你不放括号在它后面,那它可以被到处传递,并且可以赋值给别的变量而不去执行它 阅读全文
摘要:
一、原始问题 1.执行如下代码 import json def test_dumps(): data={"keys":"string",1:[2,3],"dict":{"a":"b"},"key_bytes":b'123'} ans=json.dumps(data) print(ans) if __ 阅读全文