julia-类型(第10讲)

2024-03-20 09:08
文章标签 类型 julia

本文主要是介绍julia-类型(第10讲),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Julia-类型   2020/6/7
====================================================================
1.类型操作

断言运算符::
语法:左表达式::右数据类型
用途:判断“左表达式”是否为“右数据类型”的实例,true返回“左表达式”值,false返回错误

实例:
(9.0*9.0) :: Float64,("A") :: String# (81.0, "A")
(9*9) :: String#TypeError

# ::在local变量使用:代码块
语法:变量名::类型 = 值# 变量在赋值同时声明类型

f_local() :: String=  "Tom"  

function f_local()
    name :: String = "Tom"
    name
    end
    
function f_local() :: String
    name = "Tom"
    name
    end

f_local()# "Tom"
name :: String = "Tom"#global类型-错误
local name :: String = "Tom"

====================================================================
2.函数

isa(123,Int64)                                              #测试对象是否具有给定类型:true

primitive type Ptr{T} 64 end
typeof(Float64),typeof(UnionAll),typeof(Ptr)#返回其参数的类型:(DataType, DataType, UnionAll)

supertype(Int64),supertype(Float64),supertype(Any)# 返回类型的父类型:(Signed, AbstractFloat, Any)
subtypes(AbstractFloat)#返回参数的子类型:BigFloat,Float16, Float32,Float64

eltype(["Tom",22])#获得某个数集的元素类型:Any

====================================================================
3.1.抽象类型:不能实例化,但它们是类型系统的主干
Int,Float64不是抽象类型,是原始类型。

声明:
abstract type «name» end                         # 系统默认它的父类型Any
abstract type «name» <: «supertype» end# <: 运算符意义为「是···的子类型」

用途:抽象类型允许编写范型函数,调用时用具体类型与之对应

实例:
Unsigned <: Number,Unsigned <: Real      # (true, true)

fx(x,y) = x+y
fx(1,2),fx(1.1,2.2)

====================================================================
3.3.原始类型
抽象类型可以实例化,Julia 允许声明自己的原始类型,且内置了大量的
原始类型Int8、UInt8、Int16、UInt16、Int32、UInt32、Int64、UInt64、Int128、UInt128、Float16、Float32 和 Float64…………

声明:
primitive type «name» «bits» end                         # 系统默认它的父类型Any
primitive type «name» <: «supertype» «bits» end# bits 该类型需要存储空间,name 新类型名称;
用途:
允许声明自己原始类型;内置原始类型Int,Float64...

====================================================================
3.4.复合类型
定义:struct  name... end # 复合类型是变量名域的集合

struct Person# 定义复合类型Person
    name::String
    age::Int64
    end

Jack = Person("Jack",27)                        # Person("Jack", 27)
typeof(Jack),Jack.name,Jack.age          # (Person, "Jack", 27) name,age都不允许修改

3.5.可变复合类型
定义:mutable struct  name... end

mutable struct Employee
    name::String
    age::Int64
    end

Boss = Employee("Jack",35)
Boss.name = "Rose"# "Rose"

====================================================================
4.类型共用体
定义:Union{type,...}
说明:类型共同体内定义的类型,比Any少,比原始类型多

实例:
TypeMemo = Union{Char, String}        # 定义类型共同体TypeMemo,只接受字符或字符串
"a" :: TypeMemo, "abc" :: TypeMemo# ("a", "abc")
123 :: TypeMemo# TypeError

====================================================================
5.参数复合类型
定义:struct name{T1,T2,...}
说明:参数复合类型类型可以接受参数,每一个参数值的可能组合引入一个新类型。

实例:
struct Point{T}#定义了参数复合类型Point,在这里参数有两个x、y,为入参类型(泛型)
    x::T
    y::T
    end

# Point作为一类型,下面每一个Point{T}都是它的子类型
Point{Float64} <: Point,Point{String} <: Point#(true, true)

# 尽管Point入参为Any类型但其他原始类型并非Point的子类型:
Float64 <: Point# false

# Point下各个子类型相互间也没有层级关系:
Point{Int64} <: Point{Real}# false

# 参数复合类型Point的实例化和引用格式:
struct Point{T1,T2}
    x::T1
    y::T2
    end

fx(p::Point{<: Float64})=p.x*p.y

function fx(p::Point{<: Float64})
    p.x * p.y
    end

fx(Point(1.1,2.2))# 2.4200000000000004

# 如果复合类型在引用时Point{Real}格式,将不包含Float64类型,所以:
gx(p::Point{Real})=p.x * p.y
gx(Point(1.1,2.2))# MethodError

# 为了包括包含Float64类型,使用<:运算符
gx(p::Point{<:Real})=p.x * p.y
gx(Point(1.1,2.2))# 2.4200000000000004

# 复合类型Point,可以按照构造函数的形式,定义T1、T2的类型:
Point(1,2),Point(1.2,2.3),Point(1.2,2)
# (Point{Int64,Int64}(1, 2), Point{Float64,Float64}(1.2, 2.3), Point{Float64,Int64}(1.2, 2))

参数复合类型定义可使用mutable关键字
====================================================================
6.参数化原始类型
声明:
primitive type Ptr{T} 64 end#type 关键字,T类型参数,64位操作系统
说明:
不同的T表示不同的Ptr类型,尽管都叫Ptr,但是不同类型间无父子关系

primitive type Ptr{T} 64 end
Ptr{Int64} <: Ptr,Ptr{Real} <: Ptr,Ptr{Signed} <: Ptr#(true, true, true)
Ptr{Int64} <: Ptr{Signed},Ptr{Int64} <: Ptr{Real},Ptr{Signed} <: Ptr{Real}#(false, false, false)
# primitive type类型可以理解为C里的指针,Ptr{Int64}近似于int*,Ptr{Float64}近似于double*

====================================================================
7.元组类型

数组定义:
data =["Tom",22]
arr = Array{Any,1}(nothing,1);arr[1]="Tom";;push!(arr,22)
arr==data# true

定义元组:
("Tom",22)==Tuple("Tom",22)#可下标访问;数值不能修改

变参元组类型:
关键字Tuple、Vararg,表示该类型元素数量不定。

a1 = Tuple{String,Vararg{Int}}# Tuple{String,Vararg{Int64,N} where N}
isa(("1",),a1),isa(("1",2),a1),isa(("1",2,3),a1),isa(("1",2,3.0),a1)#(true, true, true, false)

命名元组类型:
x = (a=1,b=2.2,c="abc")
x.a==x[1]

====================================================================
8.单态类型

# 简单地说Type(T)的实例就是T
isa(Float64,Type{Float64}), isa(Float64,Type{Real})#(true, false)

# Type不带参数时,所有类型对象都是它的实例,当然也包括单态类型:
isa(Float64,Type),isa(String,Type)# (true, true)

====================================================================
9.类型别名
定义:const type

const myint = Int64# Int64
myint                       # Int64 myint是Int64的别名

====================================================================
10.实例:
# 系统内置抽象类型:
function check_all_subtypes(T, space = 0)
    println("\t" ^ space, T)
    for t in subtypes(T)
        if t != Any check_all_subtypes(t, space+1) end
    end
end

check_all_subtypes(Number)
"""
Number
        Complex
        Real
                AbstractFloat
                        BigFloat
                        Float16
                        Float32
                        Float64
                AbstractIrrational
                        Irrational
                Integer
                        Bool
                        Signed
                                BigInt
                                Int128
                                Int16
                                Int32
                                Int64
                                Int8
                        Unsigned
                                UInt128
                                UInt16
                                UInt32
                                UInt64
                                UInt8
                Rational
"""
check_all_subtypes(AbstractString)
"""
AbstractString
        String
        SubString
        SubstitutionString
        Test.GenericString
"""
====================================================================


 

这篇关于julia-类型(第10讲)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ

IDEA如何将String类型转json格式

《IDEA如何将String类型转json格式》在Java中,字符串字面量中的转义字符会被自动转换,但通过网络获取的字符串可能不会自动转换,为了解决IDEA无法识别JSON字符串的问题,可以在本地对字... 目录问题描述问题原因解决方案总结问题描述最近做项目需要使用Ai生成json,可生成String类型

Mysql 中的多表连接和连接类型详解

《Mysql中的多表连接和连接类型详解》这篇文章详细介绍了MySQL中的多表连接及其各种类型,包括内连接、左连接、右连接、全外连接、自连接和交叉连接,通过这些连接方式,可以将分散在不同表中的相关数据... 目录什么是多表连接?1. 内连接(INNER JOIN)2. 左连接(LEFT JOIN 或 LEFT

Redis的Hash类型及相关命令小结

《Redis的Hash类型及相关命令小结》edisHash是一种数据结构,用于存储字段和值的映射关系,本文就来介绍一下Redis的Hash类型及相关命令小结,具有一定的参考价值,感兴趣的可以了解一下... 目录HSETHGETHEXISTSHDELHKEYSHVALSHGETALLHMGETHLENHSET

Python中异常类型ValueError使用方法与场景

《Python中异常类型ValueError使用方法与场景》:本文主要介绍Python中的ValueError异常类型,它在处理不合适的值时抛出,并提供如何有效使用ValueError的建议,文中... 目录前言什么是 ValueError?什么时候会用到 ValueError?场景 1: 转换数据类型场景

C# dynamic类型使用详解

《C#dynamic类型使用详解》C#中的dynamic类型允许在运行时确定对象的类型和成员,跳过编译时类型检查,适用于处理未知类型的对象或与动态语言互操作,dynamic支持动态成员解析、添加和删... 目录简介dynamic 的定义dynamic 的使用动态类型赋值访问成员动态方法调用dynamic 的

零基础学习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 ...]

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s