Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >有办法在Swift中获得_stable_泛型类名吗?

有办法在Swift中获得_stable_泛型类名吗?
EN

Stack Overflow用户
提问于 2015-01-30 01:07:54
回答 5查看 833关注 0票数 13

在Swift中获取类的名称非常容易,如下所示:

代码语言:javascript
运行
AI代码解释
复制
import Foundation

class Gen<T> {
    init() { }
}

func printName(obj: AnyObject) {
    dump(NSStringFromClass(obj.dynamicType))
}

let a: Gen<String> = Gen()
let b: Gen<Int> = Gen()
printName(a)
printName(b)

但是,如果运行上述代码两次,则不会产生相同的结果。

那么,是否有一种稳定的方式来实现printName (获取专门的泛型类名)?也就是说,代码的多次运行会为同一个类打印相同的字符串吗?

我正在使用最新的Xcode测试版。

一些额外要求:

  • 将传递给printName的类数量很高。
  • 可能不止一个泛型类,但不是很多。
EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2015-02-03 23:55:14

从Xcode 6.3 beta 1开始的新版本

好消息!从6.3开始,您可以:

代码语言:javascript
运行
AI代码解释
复制
toString(Gen<Int>())

然后打印出来:Gen<Swift.Int>

旧答案:

如果可以将范围缩小为T: AnyObject,则可以按以下方式实现:

代码语言:javascript
运行
AI代码解释
复制
class Gen<T: AnyObject> {
    var className: String {
        return "Gen<\(NSStringFromClass(T.self))>"
    }
}
票数 6
EN

Stack Overflow用户

发布于 2015-02-02 21:59:26

很抱歉让人失望,但这似乎是不可能的,除非您积极地编写一个新的编译器。

看看这个source。作者很好地描述了它:Note that the isa pointer of the two objects is not identical, even though both are an instance of WrapperClass. Evidently, a specialization of a generic class is a separate class at runtime.

我还在玩@objc,但这只是改变类的名称空间,但显然对类名没有影响。

票数 7
EN

Stack Overflow用户

发布于 2015-02-06 12:56:43

据我所知,这将打印Gen,并适用于任何类:

代码语言:javascript
运行
AI代码解释
复制
class Gen<T> {
    init() { }
}

func printName(obj: AnyObject) {
    let desc = reflect(obj).summary

    let scanner = NSScanner(string: desc)

    var name: NSString?

    scanner.scanUpToString(".", intoString: nil)
    scanner.scanString(".", intoString: nil)
    scanner.scanUpToString("", intoString: &name)

    if let n = name {
        println(n)
    }
}

但是,它不会给您提供专门的类型--例如Gen<String>Gen<Int> --而且我现在只在在线REPL上测试它,因此结果可能在项目或游乐场内有所不同。

您需要它来提供专门的类型,还是类名足够?

编辑:我结合了@relejo的答案和我的答案,给出了专门的类型,使用了他建议的协议和计算属性:

代码语言:javascript
运行
AI代码解释
复制
protocol GenericClassName {
    var className: String { get }
}

class Gen<T: AnyObject>: GenericClassName {
    init() { }
    var className: String {
        return NSStringFromClass(T.self)
    }
}

func printName<U: GenericClassName>(obj: U) {
    let desc = reflect(obj).summary

    let scanner = NSScanner(string: desc)

    var name: NSString?

    scanner.scanUpToString(".", intoString: nil)
    scanner.scanString(".", intoString: nil)
    scanner.scanUpToString("", intoString: &name)

    if let n = name {
        println(n + "<\(obj.className)>")
    }
}

let gen1 = Gen<NSString>()
let gen2 = Gen<NSNumber>()

printName(gen1) // Outputs: Gen<NSString>
printName(gen2) // Outputs: Gen<NSNumber>

再次编辑:再考虑一下,如果要向每个泛型类添加一个计算属性(您说只有3-4个属性,对吗?)然后让它看起来像这样:

代码语言:javascript
运行
AI代码解释
复制
class Gen<T: AnyObject> {
    init() { }
    var className: String {
        return (reflect(self).summary.componentsSeparatedByString(".").last ?? "") + "<\(NSStringFromClass(T.self))>"
    }
}

现在您可以将类名作为一个字符串获得,如下所示:

代码语言:javascript
运行
AI代码解释
复制
let gen1 = Gen<NSString>()
println(gen1.className)    // Output: Gen<NSString>

这样,您就不会破坏协议、全局函数或NSScanner (这可能是缓慢的.)。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28232474

复制
相关文章
【C#】使用IExtenderProvider为控件添加扩展属性,像ToolTip那样
- 文中的“控件”一词是广义上的说法,泛指包括ToolStripItem、MenuItem在内单个界面元素,并不特指继承自Control类的狭义控件
AhDung
2018/09/13
1.7K0
【C#】使用IExtenderProvider为控件添加扩展属性,像ToolTip那样
[Flutter Widget]Tooltip
在前面的文章中我们讲到了Wrap的用法,介绍了Flutter中的流式布局,在文章的最后让大家实现如下效果:
flyou
2018/10/16
3.2K0
bootstrap tooltip
<!doctype html> <html> <head> <meta charset="utf-8"> <title>联想控股</title> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link href="css/bootstrap.css" rel="stylesheet" type="text/css"> <script src="http://code.jquery.com/jquery.js"></script> <script src="js/bootstrap.min.js"></script> <script> ('[data-toggle="tooltip"]').tooltip() }) </script> </head> <body> <button type="button" class="btn btn-secondary" data-toggle="tooltip" data-placement="top" title="Tooltip on top"> Tooltip on top </button> <button type="button" class="btn btn-secondary" data-toggle="tooltip" data-placement="right" title="Tooltip on right"> Tooltip on right </button> <button type="button" class="btn btn-secondary" data-toggle="tooltip" data-placement="bottom" title="Tooltip on bottom"> Tooltip on bottom </button> <button type="button" class="btn btn-secondary" data-toggle="tooltip" data-placement="left" title="Tooltip on left"> Tooltip on left </button> </body> </html>
用户5760343
2019/07/07
1.4K0
jQuery Tooltip
jQuery Tooltip 插件取代了原生的工具提示框,让它们可自定义,您只需要调整它们的内容、位置和外观即可。
陈不成i
2021/07/23
1.2K0
前端实现tooltip
鼠标悬浮在问号图标上, 下方展示提示文本..tooltip { margin: 8px; padding: 8px; border: 1px solid #CCCCCC; background-color: #F6DBB3; position: absolute; z-index: 2;}.arrow-div { position: absolute; z-index: 3; display: inline-block; border-top: 1
code-x
2022/11/17
1.1K0
ElementUI中动态修改tooltip内容
在博客开发过程中,遇到这样一个需求:随着用户发布文章数量增多,每一类文章的数量在动态变化,需要在tooltip中动态修改文章数量,像下面这张图:
Marigold
2022/06/17
3.7K0
ElementUI中动态修改tooltip内容
扩展ToolBarManager、ListView和Grid控件以实现气球式的ToolTip
infragistics是全球领先的UI工具和用户体验的专家,Infragistics开发了一系列的炫目的Windows、Web、WPF和Silverlight控件,相信很多人在使用它们。我们现在的项目就在使用Infragistics的Windows Form控件集。虽然这些控件功能强大,也不可能满足你所有的需求,尤其是那些比较苛刻的最终用户的需求。比如,我们最近就接收到这样一个变态的需求:让所以菜单项、工具栏按钮、网格单元的ToolTip以气球式的样式显示。最终,我不得不通过对现有控件的扩展实现这个要求。
蒋金楠
2018/01/16
1.3K0
扩展ToolBarManager、ListView和Grid控件以实现气球式的ToolTip
Angular 自定义指令 Tooltip
Yeah,关注我的读者应该知道,上一篇文章了解 Angular 开发的内容,我们已经概览了 Angular 的相关内容。在自定义指令的部分,我们已经能够实现编写,但是,在实际场景中,我们还需要标准化的管理。
Jimmy_is_jimmy
2022/04/15
1.5K0
Angular 自定义指令 Tooltip
BOOtstrap源码分析之 tooltip、popover
一、tooltip(提示框) 源码文件: Tooltip.js Tooltip.scss 实现原理: 1、获取当前要显示tooltip的元素的定位信息(top、left、bottom、right、width、height等) 2、计算tooltip的位置,是top、left、bottom、right其中一个 3、然后根据计算的位置值,运算出坐标值 4、给tooltip应用坐标值 源码分析: 1、ownerDocument:文档;包含两个对象:<DocType>、documentElement(根节点) 2
sam dragon
2018/01/17
2K0
BOOtstrap源码分析之 tooltip、popover
tooltip(title美化)教程——jquery的特效
浏览器自带的alt和title提示太丑了,所以我们需要美化一下,百度有许多,不过对我们这些小白来说很难。 首先复制下面代码到网站底部: var sweetTitles = { x: 10, y: 20, tipElements: "a,span,img,div ", noTitle: false, init: function() { var b = this.noTitle; $(this.tipElements).each(function() { $(this).m
Youngxj
2018/06/06
5.5K0
CListCtrl实现tooltip信息提示
EnableToolTips(TRUE); m_tooltip.Create(this); m_tooltip.SetMaxTipWidth(500); m_tooltip.Activate(TRUE);
全栈程序员站长
2022/09/09
1.3K0
Bootstrap3 修改tooltip默认的颜色
.tooltip-inner { background-color: #f7df4b; color: black; } .tooltip.top .tooltip-arrow { border-top-color: #f7df4b; } .tooltip.bottom .tooltip-arrow { border
kirin
2021/01/20
1K0
echarts tooltip trigger: 'axis'没有作用
今天在使用echarts3柱形图时遇到一个问题,鼠标略过横轴时没有如期出现提示信息,相关设置如下:
johnhuster的分享
2022/03/28
2.1K0
Flutter基础widgets教程-Tooltip篇
1 Tooltip 一个文本提示工具,帮助解释一个按钮或其他用户界面,当widget长时间按下时(当用户采取其他适当操作时)显示一个提示标签 2 构造函数 Tooltip({ Key key, @required this.message, this.height, this.padding, this.margin, this.verticalOffset, this.preferBelow, this.excludeFromSemantic
青年码农
2020/10/10
9050
Flutter基础widgets教程-Tooltip篇
flask popper对tooltip做美化(flask 38)
<small data-toggle="tooltip" data-placement="top" data-timestamp="{{ message.timestamp.strftime('%Y-%m-%dT%H:%M:%SZ') }}" data-delay="500"> {{ moment(message.timestamp).fromNow(refresh=True) }} </small> <script type="text/javascript" src="{{ url_for('static', filename='js/popper.min.js') }}"></script>
用户5760343
2019/08/13
7840
【Flutter 组件集录】Tooltip 与 Overlay
今天是八月更文的最后一天,带大家看一下 Tooltip 组件的实现,从而引出 Overlay 组件的使用方式。 Tooltip 组件主要的作用是在鼠标悬浮或长按手势下触发消息提示。它继承自 StatefulWidget ,其中必须传入 String 类型的 message ,还有很多其他的参数用于配置。
张风捷特烈
2022/03/18
1.8K0
【Flutter 组件集录】Tooltip 与 Overlay
tooltip.css-2.0文档
只需在页面中引入"tooltip.css"或“tooltip.min.css”文件即可。
用户6167509
2019/09/04
7770
C#-ToolTIp和Popup简单使用
很多时候我们需要做一个提示框,来给用户说明这个元素的作用,比如鼠标移动到哪个元素上面,显示一个弹出框并显示这个元素的相关介绍,想到提示内容,我们很容易想到toolip和Popup,接下来就来分别是用一下这两个控件。
kdyonly
2023/03/03
1.2K0
基于bootstrap3响应式Tooltip提示插件
ggtooltip.js是一款非常实用的基于bootstrap 3.X的jQuery tooltip提示插件。该bootstrap jQuery tooltip插件实用简单,支持在4个方向上像素tooltip信息,支持修改tooltip的背景色、前景色和边框颜色。 该jQuery tooltip插件实用简单,支持在4个方向上像素tooltip信息,支持修改tooltip的背景色、前景色和边框颜色。它的特点有:
小狐狸说事
2022/12/01
1.1K0
基于 HTML5 Canvas 的拓扑组件 ToolTip 应用
ToolTip 效果是网页制作中常见的使用特效。当用户将鼠标悬浮在某个控件上时,ToolTip 显示并向用户展示相应的提示信息;当鼠标离开时,ToolTip 隐藏。一般情况下,我们使用 ToolTip 只是显示一句话或几个字,其实我们还可以展示很多信息。而今天的重点则是通过 Hightopo 的 HT for Web 产品来制作多种样式的 ToolTip。
HT for Web
2020/03/26
1.3K0

相似问题

仅使用XAML切换Button控件的ToolTip

22

控件WPF上的ToolTip

31

C# ToolTip问题

12

ToolTip与Popup (WPF控件)

20

正确更新控件上的ToolTip

14
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档