WebGL编程指南 - WebGL入门
初识绘图流程、缓冲区、着色器、attribute和uniform变量
先画一个蓝色的正方形
html代码:
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title></head><body onload="main()"> //指定 onload 属性,告诉浏览器<body>元素加载完从何处开始执行<canvas id="example" width="400" height="400">Please use a browser that supports "canvas"</canvas><script src="./js/DrawRectangle.js"></script></body>
</html>
JS代码:
// DrawRectangle.js
function main() {// 获取<canvas>元素let canvas = document.getElementById('example')if (!canvas) {console.log('Failed to retrieve the <canvas> element')return}// 获取绘制二维图形的绘图上下文let ctx = canvas.getContext('2d')// 绘制蓝色矩形ctx.fillStyle = 'rgba(0,0,255,1.0)'ctx.fillRect(120, 10, 150, 150)
}
HTML5引入<canvas>标签,允许JavaScript动态的绘制图形
<body οnlοad="main()"> //指定 onload 属性,告诉浏览器<body>元素加载完从何处开始执行,作为JavaScript程序的入口
绘制蓝色矩形的js程序的,为了在<canvas>上绘制二维图形,需要经过三个步骤:
- 获取<canvas>元素
- 向该元素请求二维图形的“绘制上下文”
- 在绘图上下文上调用相应的绘图函数,绘制二维图形
ctx对象的fillRect方法,方法的语法为 context.fillRect(x,y,width,height),x,y为矩形左上角的坐标,剩下两个是宽度和高度
canvas 中的坐标和 OpenGL 一致
清空绘图区示例与背景色设置(初识多缓冲区模型与颜色缓冲区)
效果:
代码:
<!DOCTYPE html>
<html lang="en"><head><meta charset="utf-8"/><meta http-equiv="X_UA_Compatible" content="IE=edge"/><meta name="viewport" content="width=device-width,inital-scale=1.0"/><title>Document</title></head><body onload="main()"><canvas id="webgl" width="400" height="400"></canvas><script src="HelloCanvas.js"></script></body>
</html>
// HelloCanvas.js
function main() {// 获取<canvas>元素let canvas = document.getElementById('webgl')// 获取WebGL绘图上下文// let gl = getWebGLContext(canvas) (书中的函数)let gl = canvas.getContext('webgl')if (!gl) {console.log('Failed to get the rendering context for WebGL')return}// 指定清空<canvas>的颜色gl.clearColor(0.0, 0.0, 0.0, 1.0) // 黑色// 清空<canvas>gl.clear(gl.COLOR_BUFFER_BIT)}
因为没找到书中的函数库,所以参考了别人的代码
示例程序中 main 函数的执行流:
设置 canvas 背景色
- 一旦指定背景色后,背景色会贮存在WebGL系统中,在下次调用
gl.clearColor()
方法之前不会改变。所以,如果未来还需要再次清空绘图区,没必要再指定一次颜色。 - 这是挂载在
WebGLRenderingContext
对象上的方法。
gl.clear(buffer)
清空颜色缓冲区将导致 WebGL 清空页面上的 <canvas> 区域
WebGL中的gl.clear()方法继承自OpenGL,基于多基本缓冲区模型。
绘制一个点 与 静态着色器
相关内容:着色器初识、使用着色器的WebGL程序结构、初始化着色器、顶点着色器及内置变量、片元着色器及内置变量、齐次坐标、WebGL坐标系统、JavaScript程序和着色器程序的协同运行机制
相关函数:initShaders(), vec4(), gl.drawArrays()
示例程序将在原点(0.0, 0.0, 0.0)处的10个像素大的红色的点。
因为WebGL处理的是三维图形,所以我们有必要为这个点指定三维坐标。
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Draw a point (1)</title>
</head>
<body onload="main()"><canvas id="webgl" width="400" height="400">Please use the browser supporting "canvas"</canvas><script src="../libs/webgl-utils.js"></script><script src="../libs/webgl-debug.js"></script><script src="../libs/cuon-utils.js"></script><script src="HelloPoint1.js"></script>
</body>
</html>
// HelloPoint1.js
// 顶点着色器程序
var VSHADER_SOURCE ='void main() {\n' +' gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n' + // 设置坐标' gl_PointSize = 10.0;\n' + // 设置尺寸'}\n'
// 片元着色器程序
var FSHADER_SOURCE ='void main() {\n' +' gl_FragColor = vec4(1.0, 0.0, 0.0, 1.0);\n' + // 设置颜色'}\n'
// 主程序
function main() {// 获取<canvas>元素let canvas = document.getElementById('webgl')// 获取WebGL绘图上下文// let gl = getWebGLContext(canvas)let gl = canvas.getContext('webgl')if (!gl) {console.log('Failed to get the rendering context for WebGL')return}// 初始化着色器if (!initShaders(gl, VSHADER_SOURCE, FSHADER_SOURCE)) {console.log('Failed to initialize shaders')return}// 设置<canvas>背景色gl.clearColor(0.0, 0.0, 0.0, 1.0)// 清空<canvas>gl.clear(gl.COLOR_BUFFER_BIT)// 绘制一个点gl.drawArrays(gl.POINTS, 0, 1)
}
着色器程序以字符串的形式嵌入在 JavaScript 文件中,在程序真正开始运行前它就已经设置好了
WebGL中有两种着色器:
- 顶点着色器(Vertex shader):顶点着色器是用来描述顶点特性(如位置、颜色等)的程序。顶点(vertex)是指二维或三维空间中的一个点,比如二维或三维图形的端点或交点。
- 片元着色器(Fragment shader):进行逐片元处理过程如光照的程序。片元(fragment)是一个WebGL术语,你可以将其理解为像素(图像的单元)。
JavaScript 读取了着色器的相关信息,然后存在 WebGL 系统中以供调用
WebGL 程序的执行流程
初始化着色器
顶点着色器先执行,它对gl_Posetion变量和gl_PointSize变量进行赋值,并将他们传入片元着色器,然后片元着色器再执行。
实际上,片元着色器并不直接接收两个变量,而是接收经过光栅化处理后的片元值,这一部分会在书的第五章进行讨论
WebGL程序包括运行在浏览器中的JavaScript和运行在WebGL系统中的着色器程序两个部分。
顶点着色器
// 顶点着色器程序
var VSHADER_SOURCE ='void main() {\n' +' gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n' + // 设置坐标' gl_PointSize = 10.0;\n' + // 设置尺寸'}\n'
顶点着色器设置了点的位置和大小。该语言本身和C语言一样,必须包含一个main()函数,main()函数前面的关键字void表示这个函数没有返回值,同时也不能指定参数。
与大多数语言一样,着色器程序使用=操作符进行赋值,将点的位置和尺寸分别赋值给gl_Position和gl_PointSize,这两个变量是内置在顶点着色器之中的:
注:gl_Position
必须被赋值,否则着色器无法正常工作;gl_PointSize
并不是必须的,默认值为1.0。
如果类型赋值错误,如10.0变成10,就会报错
gl_Position 表示顶点的位置,一般顶点只需要三个点即可,用内置函数 vec() 创建 vec4类型的变量
vec4(v0, v1, v2, v3):根据v0,v1,v2,v3值创建vec4对象
参数:
v0, v1, v2, v3: 指定4个浮点型分量;
返回值:
由v0, v1, v2, v3组成的vec4对象。
在示例中,我们添加了1.0作为函数第四分量。在WebGL(或者说OpenGL)中,将gl_Positon
设置为vec4类型的变量实际上是采用了齐次坐标的方式,因为它能提高处理三维数据的效率,所以在三维图形系统中被大量使用。关于齐次坐标可以看下面的说明:
片元着色器
顶点着色器控制点的位置和大小,片元着色器控制点的颜色。
片元着色器的作用是处理片元,使其显示在屏幕上
// 片元着色器程序
var FSHADER_SOURCE ='void main() {\n' +' gl_FragColor = vec4(1.0, 0.0, 0.0, 1.0);\n' + // 设置颜色'}\n'
绘制操作
// 绘制一个点gl.drawArrays(gl.POINTS, 0, 1)
建立着色器之后,与HelloCanvas.js
示例一样,进行设置背景色和清空绘制区域的操作,最后进行绘制操作。绘制操作采用的方法为gl.drawArrays()
。
当程序调用 gl.drawArrays() 时,顶点着色器将其执行 count 次,每次处理一个顶点
示例程序函数参数设置如下:
- 因为我们绘制的是单独的点,所以设置第一个参数为gl.POINTS;
- 设置第二个参数为0,表示从第1个顶点(虽然只有一个顶点)开始画起;
- 第三个参数count为1,表示程序中只绘制1个点
WebGL 坐标系统
本身不是左手也不是右手,可以认为时右手坐标系
由此可见,WebGL坐标系和<canvas>
绘图区的坐标系不同,需要将前者映射到后者。在<canvas>
绘图区,WebGL坐标系统如下图所示:
绘制一个点2 与 attribute变量(动态设置顶点着色器)
相关内容:用JavaScript程序从着色器外部向着色器传输数据(动态,而不是静态写在着色器中)、attribute变量、uniform变量
相关函数:gl.getAttribLocation()、gl.vertexAttrib3f()及其同族函数小结:动态设置着色器参数,主要包括以下几步:1.在着色器语言中,设置attribute或uniform变量,将变量赋值到主函数参数中;2.JavaScript程序中通过相关函数获取变量存储地址;3.通过相关函数,向该地址传输数据。
在前一节中,点的位置是直接编(“硬编码”)写在顶点着色器中的,虽然易于理解但缺乏可扩展性;这一节中,Web程序可以将顶点的位置坐标从JavaScript传到着色器程序中,然后再对应位置上绘制点
目前而言,将位置信息从JavaScript程序中传给顶点着色器,有两种方式:attribute变量和uniform变量。
- attribute变量:传输与顶点相关的数据
- uniform变量:传输那些对于所有顶点都相同(或与顶点无关)的数据
两个变量都是GLSL ES变量,被用来从外部向顶点着色器内传输数据,示例中选用attribute变量,示例代码如下:
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Draw a point (1)</title></head><body onload="main()"><canvas id="webgl" width="400" height="400">Please use the browser supporting "canvas"</canvas><!-- 书中的函数库 --><script src="./libs/webgl-utils.js"></script><script src="./libs/webgl-debug.js"></script><script src="./libs/cuon-utils.js"></script><script src="./js/HelloPoint2.js"></script></body>
</html>
// HelloPoint2.js
// 顶点着色器
var VSHADER_SOURCE ='attribute vec4 a_Position;\n' +'void main(){\n' +' gl_Position = a_Position;\n' +' gl_PointSize = 10.0;\n' +'}\n'
// 片元着色器
var FSHADER_SOURCE ='void main() {\n' +' gl_FragColor = vec4(1.0, 0.0, 0.0, 1.0);\n' + // 设置颜色'}\n'
// 主函数
function main() {// 获取<canvas>元素let canvas = document.getElementById('webgl')// 获取WebGL上下文let gl = canvas.getContext('webgl')if (!gl) {console.log('Failed to get the rendering context for WebGL')}// 初始化着色器if (!initShaders(gl, VSHADER_SOURCE, FSHADER_SOURCE)) {console.log('Failed to initialize shaders')return}// 获取attribute变量的存储位置let a_Position = gl.getAttribLocation(gl.program, 'a_Position')if (a_Position < 0) {console.log('Failed to get the storage location of a_Position')}// 将顶点位置传输给attribute变量gl.vertexAttrib3f(a_Position, 0.0, 0.0, 0.0)// 设置<canvas>背景色gl.clearColor(0.0, 0.0, 0.0, 1.0)// 清除<canvas>gl.clear(gl.COLOR_BUFFER_BIT)// 绘制一个点gl.drawArrays(gl.POINTS, 0, 1)
}
attribute变量的声明与赋值:
在顶点着色器的第一行GLSL ES语言中声明了此变量(第3行):
// 顶点着色器
var VSHADER_SOURCE ='attribute vec4 a_Position;\n' +'void main(){\n' +' gl_Position = a_Position;\n' +' gl_PointSize = 10.0;\n' +'}\n'
为了使用 attribute 变量,需要包含一下步骤:
- 在顶点着色器中,声明 attribute 变量
- 将 attribute 变量赋值给 gl_Position 变量
- 向 attribute 变量传输数据
具体使用讲解:
attribute变量的声明按照以下的格式:<存储限定符><类型><变量名>
- 关键词attribute被称为存储限定符(storage qualifier),它表示接下来的变量(示例中是a_Position)是一个attribute变量。attribute变量必须声明成全局变量,数据将从着色器外部传给该变量。
与一般的JavaScript变量赋值不同,在WebGL系统之外向系统内的变量赋值需要知道该变量的存储地址,再通过存储地址向变量传输数据。获取attribute变量地址的部分代码如下:
// 获取attribute变量的存储位置let a_Position = gl.getAttribLocation(gl.program, 'a_Position')if (a_Position < 0) {console.log('Failed to get the storage location of a_Position')}
gl.getAttribLocation(program, name):获取由name参数指定的attribute变量的存储地址。
参数:
program: 指定包含顶点着色器和片元着色器的着色器程序对象;
name: 指定想要获取其存储地址的attribute变量的名称;
返回值:
大于等于0:attribute变量的存储地址
-1:指定的attribute变量不存在,或者其命名具有gl_或webgl_前缀
向 attribute 变量赋值
// 将顶点位置传输给attribute变量gl.vertexAttrib3f(a_Position, 0.0, 0.0, 0.0)
通过存储地址向 attribute 变量赋值
代码中我们传递了三个浮点数,而a_Position变量得数据类型时vec4,此处该方法会默认将第四个分量设置为1.0。颜色值得第4个分量为1.0表示该颜色完全不透明,而齐次坐标得第4个分量为1.0使齐次坐标和三维坐标对应起来,所以1.0是一个“安全”的第4分量。下一部分对其同族函数的说明中介绍了默认填充的方式。
//矢量版本 可以接收类型化数组 矢量版本的函数在原函数的末尾加了字母‘v’
var position = new Float32Array([1.0, 2.0, 3.0, 1.0])
gl.vertexAttrib4fv(a_Position, position)
//对于接收数组的矢量版本,函数名中的数字代表所接收数组中的元素个数。
也可以加一个顶点大小数据,控制绘制的大小:部分代码
var VSHADER_SOURCE = 'attribute vec4 a_Position;\n' + 'attribute float a_PointSize;\n' +'void main(){\n' + 'gl_Position = a_Position;\n' + 'gl_PointSize = a_PointSize;\n' + '}\n'let a_PointSize = gl.getAttribLocation(gl.program,'a_PointSize');if(a_Position < 0) {console.log('Failed to get the storage location of a_Position');return;}gl.vertexAttrib3f(a_Position,0.5,0.0,0.0);gl.vertexAttrib1f(a_PointSize,50.0);
写的太长了,网页开始卡顿了,再开一篇,这一章真的很长
参考:【《WebGL编程指南》读书笔记-WebGL入门】_getwebglcontext-CSDN博客
相关文章:

WebGL编程指南 - WebGL入门
初识绘图流程、缓冲区、着色器、attribute和uniform变量 先画一个蓝色的正方形 html代码: <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta http-equiv"X-UA-Compatible" content&…...

mysql--数据类型
目录 搞定所有数据类型 一、常见数据类型分类 二、数值类型 1、bit类型 2、float类型 编辑3、decimal类型 4、字符类型 (1)char (2)varchar (3)varchar和char有甚区别? ࿰…...
代码随想录第40天|
#include <bits/stdc.h> using namespace std;vector<list<int>> graph; // 删除局部 graph,使用全局 graph vector<vector<int>> res; vector<int> path; int N, M;void dfs(int index) {if (index N) {res.push_back(path);…...

Turn-it:优化线材重构雕塑制造
🐨文章摘要abstract 电线雕塑在工业应用和日常生活中都很重要。 本文提出了一种新的制造策略,通过调整目标形状以适应电线弯曲机,然后由人工将其弯曲回目标形状。(机器弯曲人工弯曲) 该方法通过两阶段弯曲策略实现&a…...

微深节能 堆取料机动作综合检测系统 格雷母线
微深节能的堆取料机动作综合检测系统结合了格雷母线定位系统,是工业自动化领域的一项重要创新。该系统通过集成多种传感器和控制设备,实现对堆取料机的全面监控和精确控制,包括位置、速度、力度、振动以及工作状态等。格雷母线定位系统作为一…...

【JAVA面试题】什么是Springboot的自动配置以及注意事项
文章目录 强烈推荐核心概念:自动配置的关键特点:示例: 需要注意的点1.默认配置可能不适合所有场景2.Bean 冲突与覆盖3.应用启动慢的问题4.过度依赖自动配置5.安全性问题6.依赖冲突与版本兼容7.过多不必要的自动配置8.调试困难 专栏集锦 强烈推…...
华为鸿蒙开发笔记
记在前面 官方文档链接 因无法直接使用chatgpt进行编程(悲,2024/10),故记录笔记,方便查阅,基于arkts语言 DevEco 中文 deveco是默认有中文包的,所以在市场里面搜不错,而应该在已安装里面搜索,然后启用就行了 测试 对ts进行单独测试 打开entry/src/test/LocalUnit.test.…...

Go语言Gin框架的常规配置和查询数据返回json示例
文章目录 路由文件分组查询数据库并返回jsonservice层controller路由运行效果 启动多个服务 在 上一篇文章《使用Go语言的gorm框架查询数据库并分页导出到Excel实例》 中主要给大家分享了较多数据的时候如何使用go分页导出多个Excel文件并合并的实现方案,这一篇文章…...

JavaEE----多线程(二)
文章目录 1.进程的状态2.线程的安全引入3.线程安全的问题产生原因4.synchronized关键字的引入4.1修饰代码块4.2修饰实例方法4.3修饰静态方法4.4对象头介绍4.5死锁-可重入的特性 5.关于死锁的分析总结5.1死锁的分析5.2死锁成因的必要条件5.3死锁的解决方案 1.进程的状态 public…...

【K8S】快速入门Kubernetes
之前企业都是使用容器化和来构建自己的服务和应用程序,其中容器化优点有很多:提升了部署效率、稳定性、提高了资源的利用率降低了成本。 但是也带来了一些新的问题:容器的数量变得很多,管理就是一个新的问题。所以Kubernetes就出…...
如何在 MySQL 中处理大量的 DELETE 操作??
全文目录: 开篇语前言摘要简介概述DELETE 操作的基本概念常用的 DELETE 方法 核心源码解读简单 DELETE 语句批量 DELETE 示例 案例分析案例1:使用简单 DELETE 删除用户数据案例2:使用分批 DELETE 应用场景演示场景1:用户管理系统场…...

LabVIEW中句柄与引用
在LabVIEW中,句柄(Handle) 是一种用于引用特定资源或对象的标识符。它类似于指针,允许程序在内存中管理和操作复杂的资源,而不需要直接访问资源本身。句柄用于管理动态分配的资源,如队列、文件、网络连接、…...

【三十四】【QT开发应用】音量图标以及滑动条,没有代码补全的小技巧
效果展示 鼠标位于音量图标区域内,显示出滑动条。鼠标移出音量图标区域内滑动条隐藏。鼠标点击音量图标,如果此时音量为0,音量变成50,如果此时音量不为零,音量变为0。 CVolumeButton.h 音量图标头文件 #pragma once …...
Android修改第三方应用相机方向
以下修改基于Android7.1 diff --git a/frameworks/base/core/java/android/hardware/Camera.java b/frameworks/base/core/java/android/hardware/Camera.java index 8c7434b..7201481 100755 --- a/frameworks/base/core/java/android/hardware/Camera.java b/frameworks/ba…...
Python 读取文件汇总
readline和readlines的区别 使用 open()读取文件时,readline是读取文件的一行;而readlines是加载全部文档,以list形式保存每一行内容。 使用with避免资源泄露 with语句不仅限于open()函数,任何实现了上下文管理协议的对象都可以…...

云原生:一张图了解devops 中CI/CD
一个典型的云原生应用的开发和部署过程,其中涉及到的主要工具有 Git、Docker、Jenkins/CircleCI、Ansible、Kubernetes 等。以下是每个步骤的简要说明: 开发人员(Developers)使用 Git 进行版本控制,他们将代码推送到 G…...

无人机之自组网通信技术篇
无人机的自组网通信技术是一种利用无人机作为节点,通过无线通信技术实现节点间自主组网、动态路由和数据传输的技术。 一、技术原理与特点 技术原理:无人机自组网技术基于自组织网络(Ad-Hoc Network)的原理,通过无线…...
【WebLogic】Oracle发布2024年第四季度中间件安全公告
Oracle于美国时间2024年10月15日发布了 WebLogic 12c(12.2.1.4.0)和14c(14.1.1.0.0)两个大版本2024年第4季度的安全公告,涉及漏洞ID共计 6 个,包含2个高危漏洞 2 个,4个中危漏洞,其中…...
Java集合(3:Set和Map)
文章目录 Set概述哈希值HashSet去重原理LinkedHashSetTreeSet自定义排序规则 Map概述Map的基本方法Map集合的获取功能哈希表HashMap底层源码 特点注意 Set 概述 Set集合也是一个接口,继承自Collection,与List类似,都需要通过实现类来进行操…...

【Golang】Gin框架中如何定义路由
✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,…...

基于距离变化能量开销动态调整的WSN低功耗拓扑控制开销算法matlab仿真
目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.算法仿真参数 5.算法理论概述 6.参考文献 7.完整程序 1.程序功能描述 通过动态调整节点通信的能量开销,平衡网络负载,延长WSN生命周期。具体通过建立基于距离的能量消耗模型&am…...
rknn优化教程(二)
文章目录 1. 前述2. 三方库的封装2.1 xrepo中的库2.2 xrepo之外的库2.2.1 opencv2.2.2 rknnrt2.2.3 spdlog 3. rknn_engine库 1. 前述 OK,开始写第二篇的内容了。这篇博客主要能写一下: 如何给一些三方库按照xmake方式进行封装,供调用如何按…...

PPT|230页| 制造集团企业供应链端到端的数字化解决方案:从需求到结算的全链路业务闭环构建
制造业采购供应链管理是企业运营的核心环节,供应链协同管理在供应链上下游企业之间建立紧密的合作关系,通过信息共享、资源整合、业务协同等方式,实现供应链的全面管理和优化,提高供应链的效率和透明度,降低供应链的成…...
《Playwright:微软的自动化测试工具详解》
Playwright 简介:声明内容来自网络,将内容拼接整理出来的文档 Playwright 是微软开发的自动化测试工具,支持 Chrome、Firefox、Safari 等主流浏览器,提供多语言 API(Python、JavaScript、Java、.NET)。它的特点包括&a…...

跨链模式:多链互操作架构与性能扩展方案
跨链模式:多链互操作架构与性能扩展方案 ——构建下一代区块链互联网的技术基石 一、跨链架构的核心范式演进 1. 分层协议栈:模块化解耦设计 现代跨链系统采用分层协议栈实现灵活扩展(H2Cross架构): 适配层…...
【Go】3、Go语言进阶与依赖管理
前言 本系列文章参考自稀土掘金上的 【字节内部课】公开课,做自我学习总结整理。 Go语言并发编程 Go语言原生支持并发编程,它的核心机制是 Goroutine 协程、Channel 通道,并基于CSP(Communicating Sequential Processes࿰…...

视频字幕质量评估的大规模细粒度基准
大家读完觉得有帮助记得关注和点赞!!! 摘要 视频字幕在文本到视频生成任务中起着至关重要的作用,因为它们的质量直接影响所生成视频的语义连贯性和视觉保真度。尽管大型视觉-语言模型(VLMs)在字幕生成方面…...
WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)
一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解,适合用作学习或写简历项目背景说明。 🧠 一、概念简介:Solidity 合约开发 Solidity 是一种专门为 以太坊(Ethereum)平台编写智能合约的高级编…...
MySQL账号权限管理指南:安全创建账户与精细授权技巧
在MySQL数据库管理中,合理创建用户账号并分配精确权限是保障数据安全的核心环节。直接使用root账号进行所有操作不仅危险且难以审计操作行为。今天我们来全面解析MySQL账号创建与权限分配的专业方法。 一、为何需要创建独立账号? 最小权限原则…...

Reasoning over Uncertain Text by Generative Large Language Models
https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...