ELisp编程七:创建函数

2023-11-27 02:38
文章标签 函数 创建 编程 elisp

本文主要是介绍ELisp编程七:创建函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

defun原型

https://www.gnu.org/software/emacs/manual/html_node/eintr/defun.html 里面介绍的defun并不全,可能文档过于老旧了吧。

http://www.gnu.org/software/emacs/manual/html_node/elisp/Defining-Functions.html 要全点,和emacs c-h f显示的差不多


下面是Emacs c-h f显示的defun macro的帮助文档

defun is a Lisp macro.(defun NAME ARGLIST &optional DOCSTRING DECL &rest BODY)Define NAME as a function.
The definition is (lambda ARGLIST [DOCSTRING] BODY...).
See also the function `interactive'.
DECL is a declaration, optional, of the form (declare DECLS...) where
DECLS is a list of elements of the form (PROP . VALUES).  These are
interpreted according to `defun-declarations-alist'.
The return value is undefined.[forward]

参数解释

NAME 是函数名称

ARGLIST是函数接受的参数

DOCSTRING 是一个字符串,描述函数的功能,emacs帮助系统会使用它,建议每个函数作者都尽可能写这段描述

DECL是一个宏,用来对函数添加元数据,比如描述该函数要被废除

&rest 可以是interactive,有了它,可以直接在M-x中调用函数

BODY是函数体


简单函数例子

用Emacs创建一个test.el文件。编写如下代码:

(defun add2 (x)(+ 2 x))(add2 8)

第一段是定义了一个函数add2,传递任意数值x,都会加上2后返回,在这个函数的最后的括号后面运行C-x C-e,创建该函数。

然后在到第二段调用代码最后面执行C-x C-e

在Mini-buffer可以看到和为10.


复杂一点的例子


下面有一个例子
(defun sql-connect-preset (name)"Connect to a predefined SQL connection listed in `sql-connection-alist'"(eval `(let ,(cdr (assoc name sql-connection-alist))(flet ((sql-get-login (&rest what)))(sql-product-interactive sql-product)))))

sql-connect-preset是函数名
(name)是参数列表
"Connect to ..." 是描述文字
最后是body

interactive

有了(interactive),就可以通过M-x执行eval-buffer2了。不过该函数可以放在init.el中,也可以独立放在一个el文件中,然后运行M-x load-file来运行。

(defun eval-buffer2 ()(interactive)(eval-buffer nil (get-buffer-create "output")))

(interactive)是可以接受参数的,以后再细说。

局部变量
let函数用于定义一个局部变量,该变量屏蔽了其他同名的变量,但尽在let语句内部有效。
let包含了三个部分,第一是let函数,第二是varlist,第三是body,也就是可以在let块内部执行的语句。
(let ((variable value)(variable value)...)body...)

下面是一个例子:
(let ((zebra 'stripes)(tiger 'fierce))(message "One kind of animal has %s and another is %s."zebra tiger))




这篇关于ELisp编程七:创建函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/426838

相关文章

Java中对象的创建和销毁过程详析

《Java中对象的创建和销毁过程详析》:本文主要介绍Java中对象的创建和销毁过程,对象的创建过程包括类加载检查、内存分配、初始化零值内存、设置对象头和执行init方法,对象的销毁过程由垃圾回收机... 目录前言对象的创建过程1. 类加载检查2China编程. 分配内存3. 初始化零值4. 设置对象头5. 执行

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

Python创建Excel的4种方式小结

《Python创建Excel的4种方式小结》这篇文章主要为大家详细介绍了Python中创建Excel的4种常见方式,文中的示例代码简洁易懂,具有一定的参考价值,感兴趣的小伙伴可以学习一下... 目录库的安装代码1——pandas代码2——openpyxl代码3——xlsxwriterwww.cppcns.c

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

Java function函数式接口的使用方法与实例

《Javafunction函数式接口的使用方法与实例》:本文主要介绍Javafunction函数式接口的使用方法与实例,函数式接口如一支未完成的诗篇,用Lambda表达式作韵脚,将代码的机械美感... 目录引言-当代码遇见诗性一、函数式接口的生物学解构1.1 函数式接口的基因密码1.2 六大核心接口的形态学

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时