- __mkdir创建目录
选与握
c++开发语言
1、__mkdir创建一次目录charbuf[80];_getcwd(buf,sizeof(buf));//获取当前工程.cpp文件所在路径strcat(buf,"\\pictureFile\\11");stringdirName=buf;_mkdir(dirName.c_str());//一次创建两级目录2、_mkdir多次创建目录#include"stdafx.h"#include#inclu
- Java数据结构——二叉树难点
姜满月
Java数据结构java数据结构二叉树
文章目录二叉树难点1.难点一:二叉树的存储1.1C语言版1.2Java语言简陋版1.3Java语言版改进1.3.1例题1.3.2改进方法1.4Java源码汇总2.难点二:不止一种方法存储二叉树二叉树难点1.难点一:二叉树的存储1.1C语言版voidCreateBiTree(BiTree&T){//C语言创建结点T=(BiTree)malloc(sizeof(BiTNode));//向节点输值,例如
- openBMC(todo)
anjuenz87013
https://github.com/facebook/openbmc1、GPIOintgpio_open(gpio_st*g,intgpio){charbuf[128];intrc;snprintf(buf,sizeof(buf),"/sys/class/gpio/gpio%u/value",gpio);rc=open(buf,O_RDWR);if(rc==-1){rc=errno;LOG_ER
- 高阶C语言|数组名的深度解析(数组名结合sizeof与strlen的详解)
我想吃余
C语言篇c语言开发语言
欢迎讨论:在阅读过程中有任何疑问,欢迎在评论区留言,我们一起交流学习!点赞、收藏与分享:如果你觉得这篇文章对你有帮助,记得点赞、收藏,并分享给更多对C语言感兴趣的朋友!文章目录前言正文开始~1.`sizeof(数组名)`:计算整个数组的大小2.`&数组名`:取整个数组的地址3.数组名作为首元素地址的指针4.一维数组的深度解析5.字符数组的解析6.字符串数组的特别处理7.指针变量与字符串的关系8.二
- 浅谈Linux C基础9----数据链表
Oracle_666
linuxc语言运维
前言:基于C语言实现数据链表1.实现代码函数:#include"loop_list.h"//创建单向循环链表node_pcreate_loop(){node_pH=(node_p)malloc(sizeof(node));if(H==NULL){printf("空间申请失败\n");returnNULL;}H->data=0;//链表中暂无数据H->next=H;//单向循环链表,尾结点指向头结点
- 滑动窗口1
笔耕不辍cj
算法数据结构java
给定一个含有n个正整数的数组和一个正整数s,找出该数组中满足其和>=s的长度最小的连续子数组,并返回起长度。如果不存在符合条件的子数组,返回0。intmin(vector&nums,ints){ intleft=0, intn=nums.sizeof(); intsum=0; intmin_len=INT_MAX; for(intright=0;right=s) { min
- acwing搜索与图论(二)基础dijkstra算法
一缕叶
算法算法图论数据结构
#include#include#includeusingnamespacestd;constintN=510;intn,m;intg[N][N];intdist[N];boolst[N];intdijkstra(){memset(dist,0x3f,sizeofdist);dist[1]=0;for(inti=0;idist[j]))t=j;}st[t]=true;for(intj=1;j<=n
- super顺序表
守正出琦
一个月从数据结构小白到大师数据结构c语言
增删查改1顺序表1.1静态数据表开少了不够用,开多了浪费1.2动态顺序表顺序表缺陷#define_CRT_SECURE_NO_WARNINGS1#include"seqlist.h"voidSLInit(SL*ps){assert(ps);ps->a=(SLDataType*)malloc(sizeof(SLDataType)*int_capacity);if(ps->a==NULL){perro
- C语言进阶复习
Zhe_lianxi
c语言算法开发语言
今天复习了指针相关概念,前几天有个gets警告的问题,今天来解决一下。对此写一个GetStr函数,参数1:需要获取字符串的字符数组参数2:此字符数组的大小对此,这个编译警告的问题就解决了。#includevoidGetStr(char*Str,intlen);//函数声明intmain(void){charstr[128]={0};GetStr(str,sizeof(str));printf("%
- C语言 qsort 详解
Communist19
c语言开发语言
qsort1.定义:qsort,基于快速排序(QuickSort)算法的一个库函数,可以将一串整型类型、浮点类型、字符串类型、结构体类型等的数据进行排序。比冒泡排序,选择法排序好用,且速度更快。2.语法:具体语法如下:qsort(arr,sizeof(arr)/sizeof(arr[0]),sizeof(int),cmp)形参1:arr:需排序数组的首个元素的地址(切记不能用arr[0],arr[
- 实现十进制到十六进制的转换
HIST-柒月初柒
算法c#
目标是将十进制转化为十六进制,可以用取余法转化和栈的特性得到分成以下几步首先我们需要创建一个空栈typedefstruct{int*base;int*top;intstacksize;}stack;//定义栈的数据类型stacks;voidinitstack(){s.base=(int*)malloc(STACK_INIT_SIZE*sizeof(int));s.top=s.base;s.stac
- C语言优先级是怎么样的?
dami_king
随笔c语言开发语言
1.最高优先级(从高到低)1.1圆括号()说明:括号内的表达式总是最先计算,无论括号嵌套多少层。1.2一元运算符sizeof:返回数据类型的大小。++和--:前置递增/递减运算符,改变变量自身的值后再进行表达式计算。-(负号):一元负运算符,对数值进行相反数运算。+(正号):一元正运算符,一般用在数值前无实际效果,主要用于消除歧义。!:逻辑非运算符,将布尔值取反。~:按位取反运算符,对整数的二进制
- 每日一题——第八十二题
互联网打工人no1
C语言程序设计每日一练c语言
题目:将一个控制台输入的字符串中的所有元音字母复制到另一字符串中#include#include#include#include#defineMAX_INPUT1024boolisVowel(charp);intmain(){charinput[MAX_INPUT];charoutput[MAX_INPUT];printf("请输入一串字符串:\n");fgets(input,sizeof(inp
- C语言指针(2)
星霜旅人
c语言开发语言
目录数组名使用指针访问数组一维数组传参的本质二级指针数组指针数组名数组名是数组首元素的地址。intmain(){intarr1[]={1,2,3,4,5};printf("%p\n",&arr1[0]);printf("%p\n",arr1);}//都是传入数组首元素地址但是有两点例外:sizeof(数组名),这里的数组名表示整个数组,计算的是整个数组的大小。&(数组名),这里的数组名也表示整个数
- 已知两个非降序链表序列S1与S2,设计函数构造出S1与S2合并后的新的非降序链表S3。输入格式:输入分两行,分别在每行给出由若干个正整数构成的非降序序列,用−1表示序列的结尾(−1不属于这个序列
无敌的大佬
链表windows数据结构
#include#includetypedefstructnode{//创建结构体intnum;structnode*next;//指针域}node,*list;//结构体指针structnode*CreateList()//Createalinkedlistinwhichyoucanenterdataelements{intd;listhead=(list)malloc(sizeof(node)
- c语言宏不能传递参数,C语言 如何在宏定义中使用可变参数
左右不对称定律
c语言宏不能传递参数
有一个记录日志的函数,想用宏定义进行包装,简化调用方法,但是xlc报如下的错误:void_log(constintlevel,char*file,intline,constchar*fmt,...){va_listap;intcount;time_tt;structtm*st;charstr_time[255];memset(str_time,0x00,sizeof(str_time));time
- c++的运算符重载的局限性
zzt_is_me
c++开发语言
运算符重载的局限性1、无法重载的运算符.成员访问运算符::作用域运算符sizeof长度运算符?:条件运算符#预处理符号2、只能重载为成员函数的运算符在C++中,有几个函数只能被重载为成员函数,它们分别是:赋值运算符重载=,也叫赋值函数,要进行深拷贝时就需要重载。索引运算符重载[],可以把对象伪装成数组使用。函数调用运算符重载(),可以把对象伪装成函数使用。成员访问运算符重载->,可以把对象伪装成指
- 9.8笔试记录
冰榫
前端开发语言
1.在c++中哪些运算符不能重载?在C++中,有以下几个运算符不能被重载:.:成员访问运算符。例如obj.member中的.不能被重载。:::作用域解析运算符。用于指定命名空间、类等的作用域,不能被重载。?::条件运算符。如a?b:c中的?:不能被重载。sizeof:用于获取对象或类型的大小,不能被重载。2.C++中运算符优先级2.3.在C++中,转义字符是一种特殊的字符表示方式,用于表示一些无法
- 【软考】希尔排序算法分析
王佑辉
软考算法算法软考
目录1.c代码2.运行截图3.运行解析1.c代码#include#includevoidshellSort(intdata[],intn){//划分的数组,例如8个数则为[4,2,1]int*delta;intk;//i控制delta的轮次inti;//临时变量,换值inttemp;intdk;intj;k=n;delta=(int*)malloc(sizeof(int)*(n/2));i=0;d
- C语言 | Leetcode C语言题解之第392题判断子序列
DdddJMs__135
分享C语言Leetcode题解
题目:题解:boolisSubsequence(char*s,char*t){intn=strlen(s),m=strlen(t);intf[m+1][26];memset(f,0,sizeof(f));for(inti=0;i=0;i--){for(intj=0;j<26;j++){if(t[i]==j+'a')f[i][j]=i;elsef[i][j]=f[i+1][j];}}intadd=0
- 将消息队列发送接收端实现一遍。
qy3333
消息队列单片机linux
send.c#includetypedefstructmsgbuf{longmtype;charmtetx[100];}buf;#definezwlensizeof(buf)-sizeof(long)intmain(intargc,constchar*argv[]){key_tkey=ftok("./",'w');//获取密钥if(key==-1){perror("ftok");return-1;
- 16 C语言使用堆实现优先队列
天黑我就困
数据结构与算法c语言算法数据结构
#include"stdio.h"#include"stdlib.h"typedefintElemType;typedefstructMaxHeap{ElemType*arr;intsize;intcapacity;}Heap;Heap*initHeap(){Heap*heap=(Heap*)malloc(sizeof(Heap));if(heap==NULL){exit(-1);}heap->s
- 数据结构总结之最短路径
@阿奇@
最短路径图论
1.弗洛伊德算法模板题:uva10000#include#includeusingnamespacestd;intdis[105][105];intmain(){intn;intt=0;while(cin>>n,n){inta,b,s;memset(dis,-1,sizeof(dis));cin>>s;while(cin>>a>>b,a)dis[a][b]=1;inti,j;for(intk=1;
- 【时时三省】(C语言基础)指针进阶6
时时三省
【理论+经验】c语言入门c语言基础知识点c语言
山不在高,有仙则名。水不在深,有龙则灵。----CSDN时时三省例题1:sizeof(数组名)-数组名表示整个数组的-计算的是整个数组的大小&数组名-数组名表示整个数组,取出的是整个数组的地址除此之外,所有的数组名都是数组首元素的地址第一个a他有四个元素每个元素是四个字节算出来就是16他就是打印16第二个a+0这里的a表示的就不是整个数组了所以这里的a表示的是首元素的地址就是1的地址1的地址加0等
- 【C语言】操作符详解(下)
谦虚进步
C语言c语言开发语言
目录前言1.sizeof2.自增和自减(++、--)编辑3.逻辑操作符4.条件操作符(exp1?exp2:exp3)5.逗号表达式(exp1,exp2,exp3,……)6.地址操作符(*、&)7.下标引用、函数调用和结构成员([]、()、.、->)7.1[]下标引用操作符7.2()函数调用操作符7.3访问一个结构成员8.关系操作符9.操作符的属性总结前言操作数详解(上)的链接:http://t.c
- 冒泡排序;选择排序;插入排序;快排;判断大小端;位运算
kannikeside
算法排序算法数据结构
1.冒泡排序:基础时间复杂度来说:o(n^2)从左到右,相邻元素进行比较。每次比较一轮,就会找到序列中最大的一个或最小的一个。这个数就会从序列的最右边冒出来。#includeintmain(void){intstr[32]=0;inti=0;intj=0;intlen=sizeof(str)/sizeof(str[0]);inttmp=0;for(i=0;istr[i+1]){tmp=str[i]
- 剑指 Offer II 003. 前 n 个数字二进制中 1 的个数
minningl
题目:给定一个非负整数n,请计算0到n之间的每个数字的二进制表示中1的个数,并输出一个数组。示例1:输入:n=2输出:[0,1,1]解释:0-->01-->12-->10示例2:输入:n=5输出:[0,1,1,2,1,2]解释:0-->01-->12-->103-->114-->1005-->101说明:0<=n<=105进阶:给出时间复杂度为O(n*sizeof(integer))的解答非常容易
- 循环队列 、二叉树
安亿103
服务器linuxc语言学习软件构建数据结构
1、循环队列特点:只允许在队尾入队,队头出队,遵循先进先出原则不能随机访问,不能随机插入1.1循环队列创建定义两个指针分别指向队头,队尾。初始化队头,队尾为0;SeqQueue*CreateSeqQueue(intMaxLen){SeqQueue*pTmpQueue=NULL;pTmpQueue=malloc(sizeof(SeqQueue));if(NULL==pTmpQueue){return
- C语言操作符的介绍
wangjing_0522
c语言
C语言的运算符有很多种(非常多),一共有五十多种,可以分成若干类。算术操作符:+、-、*、/、%移位操作符:>位操作符:&、|、^赋值操作符:+=、-=、*=、/=、%=、>=、&=、|=、^=单目操作符:只有一个操作数1!逻辑反操作符2-负值3+正值4&取地址5sizeof操作数的类型长度(以字节为单位)6~对一个数的二进制按位取反7--前置、后置--8++前置、后置++9*间接访问操作符(解引
- C语言 | Leetcode C语言题解之第388题文件的最长绝对路径
DdddJMs__135
分享C语言Leetcode题解
题目:题解:#defineMAX(a,b)((a)>(b)?(a):(b))intlengthLongestPath(char*input){intn=strlen(input);intpos=0;intans=0;int*level=(int*)malloc(sizeof(int)*(n+1));memset(level,0,sizeof(int)*(n+1));while(pos1){len+
- JVM StackMapTable 属性的作用及理解
lijingyao8206
jvm字节码Class文件StackMapTable
在Java 6版本之后JVM引入了栈图(Stack Map Table)概念。为了提高验证过程的效率,在字节码规范中添加了Stack Map Table属性,以下简称栈图,其方法的code属性中存储了局部变量和操作数的类型验证以及字节码的偏移量。也就是一个method需要且仅对应一个Stack Map Table。在Java 7版
- 回调函数调用方法
百合不是茶
java
最近在看大神写的代码时,.发现其中使用了很多的回调 ,以前只是在学习的时候经常用到 ,现在写个笔记 记录一下
代码很简单:
MainDemo :调用方法 得到方法的返回结果
- [时间机器]制造时间机器需要一些材料
comsci
制造
根据我的计算和推测,要完全实现制造一台时间机器,需要某些我们这个世界不存在的物质
和材料...
甚至可以这样说,这种材料和物质,我们在反应堆中也无法获得......
 
- 开口埋怨不如闭口做事
邓集海
邓集海 做人 做事 工作
“开口埋怨,不如闭口做事。”不是名人名言,而是一个普通父亲对儿子的训导。但是,因为这句训导,这位普通父亲却造就了一个名人儿子。这位普通父亲造就的名人儿子,叫张明正。 张明正出身贫寒,读书时成绩差,常挨老师批评。高中毕业,张明正连普通大学的分数线都没上。高考成绩出来后,平时开口怨这怨那的张明正,不从自身找原因,而是不停地埋怨自己家庭条件不好、埋怨父母没有给他创造良好的学习环境。
- jQuery插件开发全解析,类级别与对象级别开发
IT独行者
jquery开发插件 函数
jQuery插件的开发包括两种: 一种是类级别的插件开发,即给
jQuery添加新的全局函数,相当于给
jQuery类本身添加方法。
jQuery的全局函数就是属于
jQuery命名空间的函数,另一种是对象级别的插件开发,即给
jQuery对象添加方法。下面就两种函数的开发做详细的说明。
1
、类级别的插件开发 类级别的插件开发最直接的理解就是给jQuer
- Rome解析Rss
413277409
Rome解析Rss
import java.net.URL;
import java.util.List;
import org.junit.Test;
import com.sun.syndication.feed.synd.SyndCategory;
import com.sun.syndication.feed.synd.S
- RSA加密解密
无量
加密解密rsa
RSA加密解密代码
代码有待整理
package com.tongbanjie.commons.util;
import java.security.Key;
import java.security.KeyFactory;
import java.security.KeyPair;
import java.security.KeyPairGenerat
- linux 软件安装遇到的问题
aichenglong
linux遇到的问题ftp
1 ftp配置中遇到的问题
500 OOPS: cannot change directory
出现该问题的原因:是SELinux安装机制的问题.只要disable SELinux就可以了
修改方法:1 修改/etc/selinux/config 中SELINUX=disabled
2 source /etc
- 面试心得
alafqq
面试
最近面试了好几家公司。记录下;
支付宝,面试我的人胖胖的,看着人挺好的;博彦外包的职位,面试失败;
阿里金融,面试官人也挺和善,只不过我让他吐血了。。。
由于印象比较深,记录下;
1,自我介绍
2,说下八种基本类型;(算上string。楼主才答了3种,哈哈,string其实不是基本类型,是引用类型)
3,什么是包装类,包装类的优点;
4,平时看过什么书?NND,什么书都没看过。。照样
- java的多态性探讨
百合不是茶
java
java的多态性是指main方法在调用属性的时候类可以对这一属性做出反应的情况
//package 1;
class A{
public void test(){
System.out.println("A");
}
}
class D extends A{
public void test(){
S
- 网络编程基础篇之JavaScript-学习笔记
bijian1013
JavaScript
1.documentWrite
<html>
<head>
<script language="JavaScript">
document.write("这是电脑网络学校");
document.close();
</script>
</h
- 探索JUnit4扩展:深入Rule
bijian1013
JUnitRule单元测试
本文将进一步探究Rule的应用,展示如何使用Rule来替代@BeforeClass,@AfterClass,@Before和@After的功能。
在上一篇中提到,可以使用Rule替代现有的大部分Runner扩展,而且也不提倡对Runner中的withBefores(),withAfte
- [CSS]CSS浮动十五条规则
bit1129
css
这些浮动规则,主要是参考CSS权威指南关于浮动规则的总结,然后添加一些简单的例子以验证和理解这些规则。
1. 所有的页面元素都可以浮动 2. 一个元素浮动后,会成为块级元素,比如<span>,a, strong等都会变成块级元素 3.一个元素左浮动,会向最近的块级父元素的左上角移动,直到浮动元素的左外边界碰到块级父元素的左内边界;如果这个块级父元素已经有浮动元素停靠了
- 【Kafka六】Kafka Producer和Consumer多Broker、多Partition场景
bit1129
partition
0.Kafka服务器配置
3个broker
1个topic,6个partition,副本因子是2
2个consumer,每个consumer三个线程并发读取
1. Producer
package kafka.examples.multibrokers.producers;
import java.util.Properties;
import java.util.
- zabbix_agentd.conf配置文件详解
ronin47
zabbix 配置文件
Aliaskey的别名,例如 Alias=ttlsa.userid:vfs.file.regexp[/etc/passwd,^ttlsa:.:([0-9]+),,,,\1], 或者ttlsa的用户ID。你可以使用key:vfs.file.regexp[/etc/passwd,^ttlsa:.: ([0-9]+),,,,\1],也可以使用ttlsa.userid。备注: 别名不能重复,但是可以有多个
- java--19.用矩阵求Fibonacci数列的第N项
bylijinnan
fibonacci
参考了网上的思路,写了个Java版的:
public class Fibonacci {
final static int[] A={1,1,1,0};
public static void main(String[] args) {
int n=7;
for(int i=0;i<=n;i++){
int f=fibonac
- Netty源码学习-LengthFieldBasedFrameDecoder
bylijinnan
javanetty
先看看LengthFieldBasedFrameDecoder的官方API
http://docs.jboss.org/netty/3.1/api/org/jboss/netty/handler/codec/frame/LengthFieldBasedFrameDecoder.html
API举例说明了LengthFieldBasedFrameDecoder的解析机制,如下:
实
- AES加密解密
chicony
加密解密
AES加解密算法,使用Base64做转码以及辅助加密:
package com.wintv.common;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import sun.misc.BASE64Decod
- 文件编码格式转换
ctrain
编码格式
package com.test;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
- mysql 在linux客户端插入数据中文乱码
daizj
mysql中文乱码
1、查看系统客户端,数据库,连接层的编码
查看方法: http://daizj.iteye.com/blog/2174993
进入mysql,通过如下命令查看数据库编码方式: mysql> show variables like 'character_set_%'; +--------------------------+------
- 好代码是廉价的代码
dcj3sjt126com
程序员读书
长久以来我一直主张:好代码是廉价的代码。
当我跟做开发的同事说出这话时,他们的第一反应是一种惊愕,然后是将近一个星期的嘲笑,把它当作一个笑话来讲。 当他们走近看我的表情、知道我是认真的时,才收敛一点。
当最初的惊愕消退后,他们会用一些这样的话来反驳: “好代码不廉价,好代码是采用经过数十年计算机科学研究和积累得出的最佳实践设计模式和方法论建立起来的精心制作的程序代码。”
我只
- Android网络请求库——android-async-http
dcj3sjt126com
android
在iOS开发中有大名鼎鼎的ASIHttpRequest库,用来处理网络请求操作,今天要介绍的是一个在Android上同样强大的网络请求库android-async-http,目前非常火的应用Instagram和Pinterest的Android版就是用的这个网络请求库。这个网络请求库是基于Apache HttpClient库之上的一个异步网络请求处理库,网络处理均基于Android的非UI线程,通
- ORACLE 复习笔记之SQL语句的优化
eksliang
SQL优化Oracle sql语句优化SQL语句的优化
转载请出自出处:http://eksliang.iteye.com/blog/2097999
SQL语句的优化总结如下
sql语句的优化可以按照如下六个步骤进行:
合理使用索引
避免或者简化排序
消除对大表的扫描
避免复杂的通配符匹配
调整子查询的性能
EXISTS和IN运算符
下面我就按照上面这六个步骤分别进行总结:
- 浅析:Android 嵌套滑动机制(NestedScrolling)
gg163
android移动开发滑动机制嵌套
谷歌在发布安卓 Lollipop版本之后,为了更好的用户体验,Google为Android的滑动机制提供了NestedScrolling特性
NestedScrolling的特性可以体现在哪里呢?<!--[if !supportLineBreakNewLine]--><!--[endif]-->
比如你使用了Toolbar,下面一个ScrollView,向上滚
- 使用hovertree菜单作为后台导航
hvt
JavaScriptjquery.nethovertreeasp.net
hovertree是一个jquery菜单插件,官方网址:http://keleyi.com/jq/hovertree/ ,可以登录该网址体验效果。
0.1.3版本:http://keleyi.com/jq/hovertree/demo/demo.0.1.3.htm
hovertree插件包含文件:
http://keleyi.com/jq/hovertree/css
- SVG 教程 (二)矩形
天梯梦
svg
SVG <rect> SVG Shapes
SVG有一些预定义的形状元素,可被开发者使用和操作:
矩形 <rect>
圆形 <circle>
椭圆 <ellipse>
线 <line>
折线 <polyline>
多边形 <polygon>
路径 <path>
- 一个简单的队列
luyulong
java数据结构队列
public class MyQueue {
private long[] arr;
private int front;
private int end;
// 有效数据的大小
private int elements;
public MyQueue() {
arr = new long[10];
elements = 0;
front
- 基础数据结构和算法九:Binary Search Tree
sunwinner
Algorithm
A binary search tree (BST) is a binary tree where each node has a Comparable key (and an associated value) and satisfies the restriction that the key in any node is larger than the keys in all
- 项目出现的一些问题和体会
Steven-Walker
DAOWebservlet
第一篇博客不知道要写点什么,就先来点近阶段的感悟吧。
这几天学了servlet和数据库等知识,就参照老方的视频写了一个简单的增删改查的,完成了最简单的一些功能,使用了三层架构。
dao层完成的是对数据库具体的功能实现,service层调用了dao层的实现方法,具体对servlet提供支持。
&
- 高手问答:Java老A带你全面提升Java单兵作战能力!
ITeye管理员
java
本期特邀《Java特种兵》作者:谢宇,CSDN论坛ID: xieyuooo 针对JAVA问题给予大家解答,欢迎网友积极提问,与专家一起讨论!
作者简介:
淘宝网资深Java工程师,CSDN超人气博主,人称“胖哥”。
CSDN博客地址:
http://blog.csdn.net/xieyuooo
作者在进入大学前是一个不折不扣的计算机白痴,曾经被人笑话过不懂鼠标是什么,