初探swift语言的学习笔记四-2(对上一节有些遗留进行处理)

2024-09-02 16:08

本文主要是介绍初探swift语言的学习笔记四-2(对上一节有些遗留进行处理),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者:fengsh998
原文地址:http://blog.csdn.net/fengsh998/article/details/30314359
转载请注明出处
如果觉得文章对你有所帮助,请通过留言或关注微信公众帐号fengsh998来支持我,谢谢!


在上一节中有些问题还没有弄清,在这里自己写了一下,做了一下验证,并希望能给读者有所帮助。

看例子:

例子中包括

callback函数的声明与使用

函数作为形参进行传递

函数作为返回值

函数支持泛型,当然class也支持。

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. import Foundation  
  2.   
  3. typealias Point = (Int, Int)  
  4.   
  5. let origin: Point = (0, 0)  
  6.   
  7.   
  8. //初始化函数用  
  9. func willDoit(sender : CallBackManager)  
  10. {  
  11.     println("willDoit defaulft.")  
  12. }  
  13.   
  14. func didDoit(sender : CallBackManager)  
  15. {  
  16.     println("didDoit defaulft.")  
  17. }  
  18.   
  19. class CallBackManager  
  20. {  
  21.     //声明两个函数变量  
  22.     var willdoitcallback : (CallBackManager) -> () = willDoit  
  23.     var diddoitcallback : (CallBackManager) -> () = didDoit  
  24.       
  25.     var callbackName = "hello world"  
  26.     init()  
  27.     {  
  28.           
  29.     }  
  30.   
  31.     func testCall()  
  32.     {  
  33.         self.willdoitcallback(self)  
  34.           
  35.         callbackName = "reset data"  
  36.         println("to do something.")  
  37.           
  38.         self.diddoitcallback(self)  
  39.     }  
  40.       
  41.     //函数地址作为形参传递  
  42.     func testparams(addfunc:(Int,Int)->(Int),instruction : String) ->Bool  
  43.     {  
  44.         println("3 + 5 = \(addfunc(3,5)) , 第二个参数值为:\(instruction)")  
  45.         return true  
  46.     }  
  47.       
  48.     //函数作为返回值  
  49.     func testfunctionReturn(instruction : String) -> (Int,Int) -> Int  
  50.     {  
  51.         func Multiplication(a:Int,b:Int) ->Int  
  52.         {  
  53.             return a * b  
  54.         }  
  55.           
  56.         return Multiplication  
  57.     }  
  58.       
  59.     //自动闭包类型  
  60.     //调用simpleAssert(testNumber % 2 == 0, "testNumber isn't an even number.")  
  61.     func simpleAssert(condition: @auto_closure () -> Bool, message: String) {  
  62.         if !condition() {  
  63.             println(message)  
  64.         }  
  65.     }  
  66.       
  67.     //可变参数  
  68.     func unknowParam(slist : String...)  
  69.     {  
  70.         var ret : String = ""  
  71.         for usb in slist  
  72.         {  
  73.             println(usb)  
  74.             ret += (usb + ",")  
  75.         }  
  76.     }  
  77.       
  78.     //使用泛型  
  79.     //simpleMin(17, 42)                 //整型参数  
  80.     //simpleMin(3.14159, 2.71828)       //浮点型  
  81.   
  82.     func simpleMin<T: Comparable>(x: T, y: T) -> T {  
  83.         if x < y {  
  84.             return y  
  85.         }  
  86.         return x  
  87.     }  
  88. }  

调用:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. class ViewController: UIViewController {  
  2.       
  3.       
  4.     func willcallback(callback : CallBackManager)  
  5.     {  
  6.         println("回调前结果\(callback.callbackName)")  
  7.     }  
  8.       
  9.     func didcallback(callback : CallBackManager)  
  10.     {  
  11.         println("回调后结果\(callback.callbackName)")  
  12.     }  
  13.       
  14.     func add(a:Int,b:Int) -> Int  
  15.     {  
  16.         return a + b  
  17.     }  
  18.   
  19.     override func viewDidLoad() {  
  20.         super.viewDidLoad()  
  21.   
  22.         var test = CallBackManager()  
  23.         test.willdoitcallback = willcallback  
  24.         test.diddoitcallback = didcallback  
  25.         test.testCall()  
  26.           
  27.         test.testparams(add,instruction: "测试函数作为传参")  
  28.           
  29.         let funcMulti = test.testfunctionReturn("返回函数地址")  
  30.           
  31.         let ret = funcMulti(5,5)  
  32.         println("5 * 5 = \(ret)")  
  33.           
  34.         return;}  
  35. }  

这篇关于初探swift语言的学习笔记四-2(对上一节有些遗留进行处理)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验