- C语言中实现hash表
北海冥鱼未眠
哈希算法c语言算法
引入所需的头文件一般高级语言都会有封装好的hash存储结构,使用c语言的时候同样也可以实现hash,我们自己实现的话逻辑会非常复杂,并且可能会出错,这里我们需要利用一个第三方开源的头文件uthash.h来实现,大家可以在github或者码云上面找到这个文件。另外,在官网也有它的用法介绍,链接附上;下面我们利用这个头文件来实现一个hash结构,实现添加元素、删除元素、统计元素个数、遍历元素等功能。h
- C实现的 dict 基于 avl tree
洪大宇
c语言开发语言
#include"./avltree.h"#include"./uthash/include/uthash.h"#include#include#includestructmap{int32_thashkey;void*value;structavl_nodenode;};intcmp_func(structavl_node*a,structavl_node*b,void*aux){structm
- c开源hash项目 uthash的用法总结
whatday
uthash是C的比较优秀的开源代码,它实现了常见的hash操作函数,例如查找、插入、删除等待。该套开源代码采用宏的方式实现hash函数的相关功能,支持C语言的任意数据结构最为key值,甚至可以采用多个值作为key,无论是自定义的struct还是基本数据类型,需要注意的是不同类型的key其操作接口方式略有不通。使用uthash代码时只需要包含头文件"uthash.h"即可。由于该代码采用宏的方式实
- uthash使用方法
不听话的小耳朵
力扣题解leetcode
uthash使用方法1、使用uthash存储整型typedefstruct{intid;intcount;UT_hash_handlehh;}HashNode;voidHashAdd(HashNode**pTable,intid){HashNode*node=malloc(sizeof(HashNode));memset(node,0,sizeof(HashNode));node->id=id;n
- C语言小知识——uthash使用
辣椒油li
C语言c语言哈希表
文章目录一、uthash是什么?二、基本hash用法1.添加头文件2.创建键-值对结构3.查找元素HASH_FIND_INT4.插入元素HASH_ADD_INT5.统计元素个数HASH_COUNT6.循环表中元素HASH_ITER总结一、uthash是什么?在使用python时我们常常会使用字典来进行数据检索,这个字典实际就是哈希表,通过key值来进行唯一检索。那么,在C语言中,我们应该如何实现哈
- C语言哈希表uthash的使用方法详解(附下载链接)
那年的匆匆
C++基础知识哈希表
uthash简介 由于C语言本身不存在哈希,但是当需要使用哈希表的时候自己构建哈希会异常复杂。因此,我们可以调用开源的第三方头文件,这只是一个头文件:uthash.h。我们需要做的就是将头文件复制到您的项目中,然后:#include"uthash.h"。由于uthash仅是头文件,因此没有可链接的库代码。 使用uthash添加,查找和删除通常是常数时间的操作,此哈希的目标是简约高效。它大约有1
- 【C语言】算法学习·哈希算法全解
迅攻城狮
数据结构与算法学习哈希算法散列表算法
目录C中的哈希它能做什么?快吗?是图书馆吗?C/C++和平台BSD许可下载uthash获得帮助贡献包括的额外内容历史可以直接从此处开始阅读哈希结构钥匙哈希句柄关于记忆的一句话哈希运算声明哈希添加项目更换项目查找项目删除项目计数项目迭代和排序一个完整的例子标准键类型整数键字符串键指针键结构键高级主题复合键多级哈希表多个哈希表中的项目具有多个键的项目新项目的排序插入几个排序顺序布隆过滤器(更快的未命中
- C语言HashTable/HashSet库汇总
RedB
在https://stackoverflow.com/questions/1138742/looking-for-a-good-hash-table-implementation-in-c里介绍了很多个相关的库。经过个人筛选,综合考虑执行效率、文档完善程度、支持的数据类型三方面,选择了uthash。官方文档详见:http://troydhanson.github.io/uthash/usergui
- C语言哈希表uthash的使用方法详解(附下载链接)
Carlos0321
c
uthash简介 由于C语言本身不存在哈希,但是当需要使用哈希表的时候自己构建哈希会异常复杂。因此,我们可以调用开源的第三方头文件,这只是一个头文件:uthash.h。我们需要做的就是将头文件复制到您的项目中,然后:#include"uthash.h"。由于uthash仅是头文件,因此没有可链接的库代码。 使用uthash添加,查找和删除通常是常数时间的操作,此哈希的目标是简约高效。它大约有1
- C语言哈希表uthash的使用方法详解(附下载链接)
Carlos0321
c
uthash简介 由于C语言本身不存在哈希,但是当需要使用哈希表的时候自己构建哈希会异常复杂。因此,我们可以调用开源的第三方头文件,这只是一个头文件:uthash.h。我们需要做的就是将头文件复制到您的项目中,然后:#include"uthash.h"。由于uthash仅是头文件,因此没有可链接的库代码。 使用uthash添加,查找和删除通常是常数时间的操作,此哈希的目标是简约高效。它大约有1
- uthash官方使用说明文档
逍遥子_
c/c++c语言
uthashUserGuideTroyD.Hanson,ArthurO'Dwyerversion2.1.0,December2018TableofContentsAhashinCWhatcanitdo?Isitfast?Isitalibrary?C/C++andplatformsBSDlicensedDownloaduthashGettinghelpContributingExtrasinclud
- Leetcode 697. 数组的度 C uthash
lin_AIOS
leetcodeC力扣uthash
题目给定一个非空且只包含非负数的整数数组nums,数组的度的定义是指数组里任一元素出现频数的最大值。你的任务是找到与nums拥有相同大小的度的最短连续子数组,返回其长度。示例1:输入:[1,2,2,3,1]输出:2解释:输入数组的度是2,因为元素1和2的出现频数最大,均为2.连续子数组里面拥有相同度的有如下所示:[1,2,2,3,1],[1,2,2,3],[2,2,3,1],[1,2,2],[2,
- 开源hash代码uthash的原理与用法
xuyuegang
本文从以下两篇文章参考整理而来:http://houjixin.blog.163.com/blog/static/356284102013101310454673/http://blog.csdn.net/devilcash/article/details/7230733uthash是C的比较优秀的开源代码,它实现了常见的hash操作函数,例如查找、插入、删除等待。该套开源代码采用宏的方式实现ha
- LeetCode1,167 两数之和 I,II(uthash.h)
Baal Austin
LeetCode算法题解
原题目两数之和I给定一个整数数组nums和一个目标值target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。示例:给定nums=[2,7,11,15],target=9因为nums[0]+nums[1]=2+7=9所以返回[0,1]来源:力扣(LeetCode)链接:https://leetcode
- uthash
沈万三gz
linux/unixc基础计算机基础C/C++
在软件开发中,不可不免的会使用到hash表,hash表的优点这里就不说了,以下介绍一个hash表的C实现,uthash是用宏实现的,使用的时候非常方便,只用包含uthash.h即可。Uthash的三个数据结构:1.typedefstructUT_hash_bucket{structUT_hash_handle*hh_head;unsignedcount;unsignedexpand_mult;}U
- utHash.h接口学习实例
s651665496
编程练习题
typedefstructChainNode{structChainNode*next;char*data;//文件路径+文件名}ChainNode;typedefstructChain{structChainNode*head;intcount;}Chain;#defineMAX_CONTEXT_LEN50typedefstructHash{charkey[MAX_CONTEXT_LEN+2];
- c开源库uthash的使用
aabond
githubc
一、uthash概述uthash是一个用c语言编写的开源库,使用宏实现了哈希表的增删改查等功能github地址https://github.com/troydhanson/uthash官方文档http://troydhanson.github.io/uthash/userguide.htmlleetcodec编译器支持uthash—2019年4月8日更新----二、uthash使用初始化uthas
- leetcode刷题总结(uthash)
_soloangel
1.全局变量一定要在函数开头重新初始化!!2.uthash的head一定要初始化为NULL3.uthashkey的内存一定要每次malloc栈的学习;https://www.cnblogs.com/tongye/p/9687442.html字符串操作:voidqsort(void*base,intnelem,unsignedintwidth,int(*pfCompare)(constvoid*,c
- 开源库“uthash.h”使用方法记录
黑默丁格
Chash
"uthash.h"是一个非常好用的C语言关于哈希表的开源库,现将此使用方法做一记录。“uthash.h”直接从GitHub上Clone就行了。使用时#include"uthash.h"即可。下面重点说一下相关函数使用方法。首先需要一个结构体:structhash_table{intkey;intvalue;//anytypeUT_hash_handlehh;//necessary};typede
- C言语哈希表(uthash)简介
Super_HQ
c/c++windowslinux
一、哈希表的概念及作用在一般的线性表或者树中,我们所储存的值写它的存储位置的关系是随机的。因此,在查找过程中,需要一系列的与关键字的比较。算法的时间复杂度与比较的次数有关。线性表查找的时间复杂度为O(n)而平衡二叉树的查找的时间复杂度为O(log(n))。无论是采用线程表或是树进行存储,都面临面随着数据量的增大,查找速度将不同程度变慢的问题。而哈希表正好解决了这个问题。它的主要思想是通过将值与其存
- C开源hash代码uthash的用法总结(2)
逍遥子_
c/c++C/C++
5.完整程序例子5.1.key类型为int的完整的例子#include/*gets*/#include/*atoi,malloc*/#include/*strcpy*/#include"uthash.h"structmy_struct{intikey;/*key*/charvalue[10];UT_hash_handlehh;/*makesthisstructurehashable*/};stat
- 开源库uthash第一弹uthash.h
konishi5202
文章目录一、简介1.1uthash介绍1.2uthash能做什么1.3uthash效率1.4源码获取二、简单使用2.1定义hash数据结构2.2从hash表查找item2.3向hash表添加item2.4从hash删除item三、详细介绍3.1常用操作3.1.1声明hash表3.1.2添加item3.1.3替换item3.1.4查找item3.1.5删除item3.1.6统计item3.1.7迭代
- 【STL】哈希表 uthash.h
watl0
C++
散列表(Hashtable,也叫哈希表),是根据关键字(Keyvalue)而直接访问在内存存储位置的数据结构。线性表查找的时间复杂度为O(n)而平衡二叉树的查找的时间复杂度为O(log(n))。无论是采用线程表或是树进行存储,都面临面随着数据量的增大,查找速度将不同程度变慢的问题。而哈希表正好解决了这个问题。给定表M,存在函数f(key),对任意给定的关键字值key,代入函数后若能得到包含该关键字
- C开源hash代码uthash的用法总结(1)
逍遥子_
c/c++C/C++
uthash是C的比较优秀的开源代码,它实现了常见的hash操作函数,例如查找、插入、删除等待。该套开源代码采用宏的方式实现hash函数的相关功能,支持C语言的任意数据结构最为key值,甚至可以采用多个值作为key,无论是自定义的struct还是基本数据类型,需要注意的是不同类型的key其操作接口方式略有不通。使用uthash代码时只需要包含头文件"uthash.h"即可。由于该代码采用宏的方式实
- C语言哈希表uthash的使用方法详解(附下载链接)
飞猪飞飞
数据结构与算法分析uthash数据结构与算法分析C语言leetcode力扣
工科生一枚,热衷于底层技术开发,有强烈的好奇心,感兴趣内容包括单片机,嵌入式Linux,Uboot等,欢迎学习交流!爱好跑步,打篮球,睡觉。欢迎加我QQ1500836631(备注CSDN),一起学习交流问题,分享各种学习资料,电子书籍,学习视频等。uthash简介 由于C语言本身不存在哈希,但是当需要使用哈希表的时候自己构建哈希会异常复杂。因此,我们可以调用开源的第三方头文件,这只是一个头文件:
- 浅析uthash系列之三:打印uthash工具
JT_Notes
打印uthashuthash版本:2.0.2作者:jafon.tian转载请注明出处:https://blog.csdn.net/JT_Notes为了能直观的看到hash表的情况,下面提供一种将hash表详情打印到标准输出或文件的方式。整套打印采用宏定义的方式,对外提供两个API函数名称参数PRINT_UTHASH(head)基于PRINT_UTHASH_HH的宏PRINT_UTHASH_HH(h
- 哈希算法原理
To-Be-A-Better-Man
数据结构
哈希原理及uthash源码分析应用背景众所周知,数组的特点是,可以随机访问,即寻址容易,但插入和删除困难;链表的特点是,不支持随机访问,即寻址困难,但插入和删除容易;哈希结构是为了综合数组和链表的特性,而设计产生的一种数据结构,即它同时满足寻址容易,和方便插入和删除的特性;哈希原理哈希表(或称散列表)引入的时是一种最有效的检索方法:散列方法。从本质上来讲哈希表是一个数组,通过特殊的索引值来访问数组
- cocos2dx-实现CCDictionary的hash库uthash详解
CodeWorld_Flying
游戏数据结构与算法游戏引擎
uthash详解CCDictionary底层用的是uthash,追踪CCDictionary的接口,查看CCDictionary是如何利用uthash的接口的,以及uthash是怎么实现的。下面是uthash的类图:tail方便uthash快速索引所有对象,每个bucket就是一个拉链法hash表的一个链表。客户变量m_pElements指向客户所有加入uthash中的客户对象构成的链表第一个元素
- Swoole 源码分析——基础模块之HashMap
leoyang90
HashMap的数据结构HashMap的数据结构很简单,就是一个根节点、一个迭代器还有一个析构函数HashMap比较复杂的地方在于其节点swHashMap_node的UT_hash_handle数据成员,该数据成员是C语言hash库uthash,HashMap大部分功能依赖于这个uthash。swHashMap_node中key_int是键值的长度,key_str是具体的键值,data是value
- 【leetcode】uthash专题
BHY_
leetcode
本文持续更新leetcode上适用于C语言uthash题目解法:题目:1.两数之和链接:https://leetcode-cn.com/problems/two-sum/解析:num数组值作为key,数组下标作为val。答案:typedefstruct{intnum;}uthash_key_s;typedefstruct{intindex;//数组下标}uthash_val_s;typedefst
- 面向对象面向过程
3213213333332132
java
面向对象:把要完成的一件事,通过对象间的协作实现。
面向过程:把要完成的一件事,通过循序依次调用各个模块实现。
我把大象装进冰箱这件事为例,用面向对象和面向过程实现,都是用java代码完成。
1、面向对象
package bigDemo.ObjectOriented;
/**
* 大象类
*
* @Description
* @author FuJian
- Java Hotspot: Remove the Permanent Generation
bookjovi
HotSpot
openjdk上关于hotspot将移除永久带的描述非常详细,http://openjdk.java.net/jeps/122
JEP 122: Remove the Permanent Generation
Author Jon Masamitsu
Organization Oracle
Created 2010/8/15
Updated 2011/
- 正则表达式向前查找向后查找,环绕或零宽断言
dcj3sjt126com
正则表达式
向前查找和向后查找
1. 向前查找:根据要匹配的字符序列后面存在一个特定的字符序列(肯定式向前查找)或不存在一个特定的序列(否定式向前查找)来决定是否匹配。.NET将向前查找称之为零宽度向前查找断言。
对于向前查找,出现在指定项之后的字符序列不会被正则表达式引擎返回。
2. 向后查找:一个要匹配的字符序列前面有或者没有指定的
- BaseDao
171815164
seda
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
public class BaseDao {
public Conn
- Ant标签详解--Java命令
g21121
Java命令
这一篇主要介绍与java相关标签的使用 终于开始重头戏了,Java部分是我们关注的重点也是项目中用处最多的部分。
1
- [简单]代码片段_电梯数字排列
53873039oycg
代码
今天看电梯数字排列是9 18 26这样呈倒N排列的,写了个类似的打印例子,如下:
import java.util.Arrays;
public class 电梯数字排列_S3_Test {
public static void main(S
- Hessian原理
云端月影
hessian原理
Hessian 原理分析
一. 远程通讯协议的基本原理
网络通信需要做的就是将流从一台计算机传输到另外一台计算机,基于传输协议和网络 IO 来实现,其中传输协议比较出名的有 http 、 tcp 、 udp 等等, http 、 tcp 、 udp 都是在基于 Socket 概念上为某类应用场景而扩展出的传输协
- 区分Activity的四种加载模式----以及Intent的setFlags
aijuans
android
在多Activity开发中,有可能是自己应用之间的Activity跳转,或者夹带其他应用的可复用Activity。可能会希望跳转到原来某个Activity实例,而不是产生大量重复的Activity。
这需要为Activity配置特定的加载模式,而不是使用默认的加载模式。 加载模式分类及在哪里配置
Activity有四种加载模式:
standard
singleTop
- hibernate几个核心API及其查询分析
antonyup_2006
html.netHibernatexml配置管理
(一) org.hibernate.cfg.Configuration类
读取配置文件并创建唯一的SessionFactory对象.(一般,程序初始化hibernate时创建.)
Configuration co
- PL/SQL的流程控制
百合不是茶
oraclePL/SQL编程循环控制
PL/SQL也是一门高级语言,所以流程控制是必须要有的,oracle数据库的pl/sql比sqlserver数据库要难,很多pl/sql中有的sqlserver里面没有
流程控制;
分支语句 if 条件 then 结果 else 结果 end if ;
条件语句 case when 条件 then 结果;
循环语句 loop
- 强大的Mockito测试框架
bijian1013
mockito单元测试
一.自动生成Mock类 在需要Mock的属性上标记@Mock注解,然后@RunWith中配置Mockito的TestRunner或者在setUp()方法中显示调用MockitoAnnotations.initMocks(this);生成Mock类即可。二.自动注入Mock类到被测试类 &nbs
- 精通Oracle10编程SQL(11)开发子程序
bijian1013
oracle数据库plsql
/*
*开发子程序
*/
--子程序目是指被命名的PL/SQL块,这种块可以带有参数,可以在不同应用程序中多次调用
--PL/SQL有两种类型的子程序:过程和函数
--开发过程
--建立过程:不带任何参数
CREATE OR REPLACE PROCEDURE out_time
IS
BEGIN
DBMS_OUTPUT.put_line(systimestamp);
E
- 【EhCache一】EhCache版Hello World
bit1129
Hello world
本篇是EhCache系列的第一篇,总体介绍使用EhCache缓存进行CRUD的API的基本使用,更细节的内容包括EhCache源代码和设计、实现原理在接下来的文章中进行介绍
环境准备
1.新建Maven项目
2.添加EhCache的Maven依赖
<dependency>
<groupId>ne
- 学习EJB3基础知识笔记
白糖_
beanHibernatejbosswebserviceejb
最近项目进入系统测试阶段,全赖袁大虾领导有力,保持一周零bug记录,这也让自己腾出不少时间补充知识。花了两天时间把“传智播客EJB3.0”看完了,EJB基本的知识也有些了解,在这记录下EJB的部分知识,以供自己以后复习使用。
EJB是sun的服务器端组件模型,最大的用处是部署分布式应用程序。EJB (Enterprise JavaBean)是J2EE的一部分,定义了一个用于开发基
- angular.bootstrap
boyitech
AngularJSAngularJS APIangular中文api
angular.bootstrap
描述:
手动初始化angular。
这个函数会自动检测创建的module有没有被加载多次,如果有则会在浏览器的控制台打出警告日志,并且不会再次加载。这样可以避免在程序运行过程中许多奇怪的问题发生。
使用方法: angular .
- java-谷歌面试题-给定一个固定长度的数组,将递增整数序列写入这个数组。当写到数组尾部时,返回数组开始重新写,并覆盖先前写过的数
bylijinnan
java
public class SearchInShiftedArray {
/**
* 题目:给定一个固定长度的数组,将递增整数序列写入这个数组。当写到数组尾部时,返回数组开始重新写,并覆盖先前写过的数。
* 请在这个特殊数组中找出给定的整数。
* 解答:
* 其实就是“旋转数组”。旋转数组的最小元素见http://bylijinnan.iteye.com/bl
- 天使还是魔鬼?都是我们制造
ducklsl
生活教育情感
----------------------------剧透请原谅,有兴趣的朋友可以自己看看电影,互相讨论哦!!!
从厦门回来的动车上,无意中瞟到了书中推荐的几部关于儿童的电影。当然,这几部电影可能会另大家失望,并不是类似小鬼当家的电影,而是关于“坏小孩”的电影!
自己挑了两部先看了看,但是发现看完之后,心里久久不能平
- [机器智能与生物]研究生物智能的问题
comsci
生物
我想,人的神经网络和苍蝇的神经网络,并没有本质的区别...就是大规模拓扑系统和中小规模拓扑分析的区别....
但是,如果去研究活体人类的神经网络和脑系统,可能会受到一些法律和道德方面的限制,而且研究结果也不一定可靠,那么希望从事生物神经网络研究的朋友,不如把
- 获取Android Device的信息
dai_lm
android
String phoneInfo = "PRODUCT: " + android.os.Build.PRODUCT;
phoneInfo += ", CPU_ABI: " + android.os.Build.CPU_ABI;
phoneInfo += ", TAGS: " + android.os.Build.TAGS;
ph
- 最佳字符串匹配算法(Damerau-Levenshtein距离算法)的Java实现
datamachine
java算法字符串匹配
原文:http://www.javacodegeeks.com/2013/11/java-implementation-of-optimal-string-alignment.html------------------------------------------------------------------------------------------------------------
- 小学5年级英语单词背诵第一课
dcj3sjt126com
englishword
long 长的
show 给...看,出示
mouth 口,嘴
write 写
use 用,使用
take 拿,带来
hand 手
clever 聪明的
often 经常
wash 洗
slow 慢的
house 房子
water 水
clean 清洁的
supper 晚餐
out 在外
face 脸,
- macvim的使用实战
dcj3sjt126com
macvim
macvim用的是mac里面的vim, 只不过是一个GUI的APP, 相当于一个壳
1. 下载macvim
https://code.google.com/p/macvim/
2. 了解macvim
:h vim的使用帮助信息
:h macvim
- java二分法查找
蕃薯耀
java二分法查找二分法java二分法
java二分法查找
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年6月23日 11:40:03 星期二
http:/
- Spring Cache注解+Memcached
hanqunfeng
springmemcached
Spring3.1 Cache注解
依赖jar包:
<!-- simple-spring-memcached -->
<dependency>
<groupId>com.google.code.simple-spring-memcached</groupId>
<artifactId>simple-s
- apache commons io包快速入门
jackyrong
apache commons
原文参考
http://www.javacodegeeks.com/2014/10/apache-commons-io-tutorial.html
Apache Commons IO 包绝对是好东西,地址在http://commons.apache.org/proper/commons-io/,下面用例子分别介绍:
1) 工具类
2
- 如何学习编程
lampcy
java编程C++c
首先,我想说一下学习思想.学编程其实跟网络游戏有着类似的效果.开始的时候,你会对那些代码,函数等产生很大的兴趣,尤其是刚接触编程的人,刚学习第一种语言的人.可是,当你一步步深入的时候,你会发现你没有了以前那种斗志.就好象你在玩韩国泡菜网游似的,玩到一定程度,每天就是练级练级,完全是一个想冲到高级别的意志力在支持着你.而学编程就更难了,学了两个月后,总是觉得你好象全都学会了,却又什么都做不了,又没有
- 架构师之spring-----spring3.0新特性的bean加载控制@DependsOn和@Lazy
nannan408
Spring3
1.前言。
如题。
2.描述。
@DependsOn用于强制初始化其他Bean。可以修饰Bean类或方法,使用该Annotation时可以指定一个字符串数组作为参数,每个数组元素对应于一个强制初始化的Bean。
@DependsOn({"steelAxe","abc"})
@Comp
- Spring4+quartz2的配置和代码方式调度
Everyday都不同
代码配置spring4quartz2.x定时任务
前言:这些天简直被quartz虐哭。。因为quartz 2.x版本相比quartz1.x版本的API改动太多,所以,只好自己去查阅底层API……
quartz定时任务必须搞清楚几个概念:
JobDetail——处理类
Trigger——触发器,指定触发时间,必须要有JobDetail属性,即触发对象
Scheduler——调度器,组织处理类和触发器,配置方式一般只需指定触发
- Hibernate入门
tntxia
Hibernate
前言
使用面向对象的语言和关系型的数据库,开发起来很繁琐,费时。由于现在流行的数据库都不面向对象。Hibernate 是一个Java的ORM(Object/Relational Mapping)解决方案。
Hibernte不仅关心把Java对象对应到数据库的表中,而且提供了请求和检索的方法。简化了手工进行JDBC操作的流程。
如
- Math类
xiaoxing598
Math
一、Java中的数字(Math)类是final类,不可继承。
1、常数 PI:double圆周率 E:double自然对数
2、截取(注意方法的返回类型) double ceil(double d) 返回不小于d的最小整数 double floor(double d) 返回不大于d的整最大数 int round(float f) 返回四舍五入后的整数 long round