首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Java 安全使用接口引用

Android 开发我们经常会持有接口的引用,或者注册事件的监听,诸如系统服务的通知,点击事件的回调等,虽不胜枚举,但大部分监听都需要我们去实现一个接口,因此我们今天就拿注册一个回调监听举例:...操作符只有对象引用不为空才会分派调用 我们接下来分别拿Kotlin 和Groovy 举例: Kotlin 中使用 ' ?....为了验证假设,我们分别用kotlinc 和groovyc 将之前的代码编译成class 文件,然后再使用javap 指令进行反汇编。...:(Ljava/lang/Object;)Ljava/lang/Object; 14: pop 15: return ...... } 需要注意的是,groovy 文件在编译过程由编译器生成大量的不存在于源代码的额外函数和变量...为了安全使用定义接口中的函数,我做了这个小工具,目前已经开源,所有代码都可以通过github 获取,希望这个避免空指针的“接口救生圈”能够让你在Java 的海洋尽情遨游。

1.8K20

HTML如何使用CSS?

使用内嵌式 CSS 用法 CSS 代码将被集中放在 标记,这样方便查找,对后期维护比较方便,页面代码也会减少。...使用链接式 CSS,可以设计整个网站,将多个页面都会用到的 CSS 样式定义一个或多个 文件,然后需要用到该样式的 HTML 网页通过 标记链接这些 文件,通过链接式 CSS 可以降低整个网站的页面代码冗余并提高网站的可维护性...被导入的 HTML 文件初始化时,会将该 CSS 文件导入 HTML 文件,作为此 HTML 文件的一部分,类似于内嵌式的效果,而链接式是 HTML 的标记需要 CSS 样式的时候才会以链接的方式引入进来...例如,可以 文件不写任何 CSS 代码,只写 ,这样所有导入或链接到该 CSS 文件HTML 页面都可以使用 定义的所有样式效果。...这时解决 CSS 冲突你就要了解 HTML使用 CSS 的优先级规则: 内联式 > 内嵌式 > 外部样式; 多个样式,后出现的样式的优先级高于先出现的样式; 样式,选择器的优先级: 样式

8.4K100

hexo 无痛使用本地图片

1 起因 hexo 中使用本地图片是件非常让人纠结的事情, markdown 里的图片地址似乎永远无法和最后生成的网页保持一致。...这些问题使得我一度不愿意使用本地图片而选择用图床,但被移动运营商无耻的横条广告逼得打算上 https,图床只支持 http 就成了问题。...显然这样本地的编辑器里完全不能正确识别图片的位置。...1.2 asset-image hexo 2.x 出现的插件,后来被吸纳进 hexo 3 core ,用法的介绍见 资源文件夹 | Hexo 。...比较尴尬的是,这种方法直接放弃了 markdown 原来的语法,使用类似 的语法,。markdown 本来有插入图片的语法不好好支持,专门用一个新的语法来插入本地图片,让我这种强迫症不太能接受。

2.4K100

通过 ReferenceOutputAssembly=False 引用项目,不额外引入依赖文件

通过本文的方法,你可以 A 项目编译,确保 B 项目已经编译,而无需引用 B。...ReferenceOutputAssembly=False 依然项目中使用往常习惯的方法设置项目引用: 但是,项目引用设置完成之后,需要打开项目的项目文件(.csproj)给 ProjectReference...Walterlv.Demo.Build.csproj" ReferenceOutputAssembly="false" /> 上面的 ProjectReference 是 Sdk 风格的 csproj 文件的项目引用...NuGet 包附带其他文件 如果要生成 NuGet 包,我们有时需要多个项目生成的文件来共同组成一个 NuGet 包,这个时候我们需要的仅仅是把其他项目生成的文件放到 NuGet 包,而不是真的需要在...当使用 ReferenceOutputAssembly 来引用项目,最终生成的 NuGet 包中就不会生成对这些项目的依赖。

20320

本地KVM安装使用Cloud-init

本文主要研究本地KVM虚拟机,也就是没有云平台的情况下,如何使用cloud-init进行初始化工作。示例虚拟机的操作系统是CentOS 7.1。...安装 虚拟机内安装cloud-init: yum install cloud-init -y 安装完后,配置文件/etc/cloud目录,主配置文件为/etc/cloud/cloud.cfg DataSource...因此这种模式需要先配置好网络; Config drive 把数据封装进一个iso9660(也支持vfat,但是不常见)文件系统的镜像,然后把这个镜像以光驱(ide接口)的形式挂载到虚拟机,虚拟机开机后...cloud-init会自动去该镜像获取数据。...user-data cat user-data #cloud-config chpasswd: list: | root:123456 expire: false ssh_pwauth: true 总结 本文测试了无云平台管理的本地

1.4K10

RAC误将数据文件创建在本地的修正

用户创建表空间误将数据文件放到了本地盘,重启数据库一个实例启动不了,只能offline该表空间后启动数据库。现用户想知道怎样能把这个表空间数据文件的数据恢复出来。...测试目的:验证RAC误将数据文件创建在本地的修复办法 环境说明: 两节点RAC,数据库名为db10g 版本10.2.0.5 使用了ASM作为共享存储解决方案。...ONLINE  ONLINE    rac10g2    ora....0g2.vip application    ONLINE  ONLINE    rac10g2  2,处理过程 由于该过程需要从本地盘把数据文件迁移到...10gR2,我们可以使用RMAN命令备份和恢复ASM文件使用ASMCMD命令可以浏览和操纵目录结构。...建错的表空间test1数据文件节点2,所以只能从节点2上打开。

52910

使用nanoLinux编辑文件

与基本的文本编辑相比,nano提供许多额外的特性,例如:交互式的查找和替换,定位到指定的行列,自动缩进,特性切换,国际化支持,以及文件名标记完成。本教程,我们将介绍一些帮助您入门的基本知识。...使用nano打开系统文件 从终端输入nano和文件名。如果该文件不存在,nano将在您指定的位置创建一个新的临时版本。...在此示例,我们将使用sudo权限打开系统的hosts文件: sudo nano /etc/hosts 使用上面的示例打开系统主机文件,结果类似于以下内容: 默认视图中,nano将在顶部标题栏的中心显示正在编辑的文件...底部,快捷方式列表显示常用命令,其中^代表CTRL键。要保存,按住CTRL并按O(对于Write * O * ut); 按CTRL + X退出。...nano快捷方式 ^ W:在打开的文件搜索 ALT + W:找到下一个搜索实例 ^ O:保存文件 ^ K:删除整行 ^ U:粘贴整行 ^ T:查看文件浏览器 ^ X:退出 更多信息 有关此主题的其他信息

7.1K40

项目文件 csproj 或者 MSBuild 的 Target 中使用 % 引用集合每一项的属性

在编写项目文件或者 MSBuild Target 文件的时候,我们经常会使用 来定义集合的一项。定义的同时,我们也会额外指定一些属性。...WalterlvX 集合的时候,我们使用了 @(Compile) 来获取所有需要编译的文件。...定义 WalterlvY 集合的时候,我们使用了 %(Compile.FileName) 来获取编译文件文件名。...于是,你警告信息中看到的两个警告信息里面,一个输出了 Compile 集合每一项的标识符(通常是相对于项目文件的路径),另一个输出了每一个 Compile 项的 FileName 属性。...需要注意,如果 % 得到的项某个属性为空,那么这一项最终形成的新集合是不存在的。

19650

Linux 本地挂载 Dropbox 文件夹的命令方法

,运行以下命令以安装 dbxfs: $ pip3 install dbxfs 本地挂载 Dropbox 文件夹 创建一个挂载点以将 Dropbox 文件夹挂载到本地文件系统。...$ mkdir ~/mydropbox 然后,使用 dbxfs 本地挂载 dropbox 文件夹,如下所示: $ dbxfs ~/mydropbox 你将被要求生成一个访问令牌: 要生成访问令牌,只需...从现在开始,你可以看到你的 Dropbox 文件夹已挂载到本地文件系统。 更改访问令牌存储路径 默认情况下,dbxfs 会将 Dropbox 访问令牌存储系统密钥环或加密文件。...但是,你可能希望将其存储 gpg 加密文件或其他地方。如果是这样,请在 Dropbox 开发者应用控制台上创建个人应用来获取访问令牌。 创建应用后,单击下一步的生成按钮。...,使用 dbxfs 在你的文件系统本地挂载 Dropfox 文件夹并不复杂。

3.5K30

如何使用 TSX Node.js 本地运行 TypeScript

最有趣的部分是,TSX被开发为Node的完整替代品,因此您实际上可以将TSX用作TypeScript REPL,只需使用npm i -g tsx全局安装它,终端运行tsx,然后就可以原生地编写TSX...但更酷的是,您可以在运行文件使用--loader tsx为所有TypeScript文件加载TSX。...TSX作为加载器通过加载器运行一个文件(或所有文件)很简单,只需package.json创建一个启动脚本,并使用以下内容:"scripts": { "start": "node --loader...使用TSX作为加载器不允许将其与其他选项一起使用,例如观察模式。扩展功能自Node 20.6版本以来,我们可以直接加载.env文件存在的环境配置文件。但如何同时使用加载器和配置文件呢?...重要提示:直接从磁盘加载TS文件使用加载器进行编译比先进行转译然后直接传递JavaScript文件要慢得多,因此建议仅在开发环境执行此操作。

1.2K10

使用 Ruby 或 Python 文件查找

对于经常使用爬虫的我来说,大多数文本编辑器都会有“文件查找”功能,主要是方便快捷的查找自己说需要的内容,那我有咩有可能用Ruby 或 Python实现类似的查找功能?这些功能又能怎么实现?...问题背景许多流行的文本编辑器都具有“文件查找”功能,该功能可以一个对话框打开,其中包含以下选项:查找: 指定要查找的文本。文件筛选器: 指定要搜索的文件类型。开始位置: 指定要开始搜索的目录。...报告: 指定要显示的结果类型,例如文件名、文件计数或两者兼有。方法: 指定要使用的搜索方法,例如正则表达式或纯文本搜索。...regex_search:指定是否使用正则表达式进行搜索。脚本将返回一个包含所有匹配文件文件名列表,或者如果指定了报告文件名选项,则返回一个包含所有匹配文件文件名和行号的列表。...上面就是两种语实现在文件查找的具体代码,其实看着也不算太复杂,只要好好的去琢磨,遇到的问题也都轻而易举的解决,如果在使用中有任何问题,可以留言讨论。

7310

Webpack使用ReactRefreshWebpackPlugin对JSX文件进行本地热更新解析 $RefreshSig$ is not defined

前提最近在进行Webpack5学习,学习到HMR,也就是模块热替换,也叫模块热更新的时候,遇到了一个问题。...问题在进行开发环境内模块热更新的时候,React是借助于React Hot Loader来实现的HMR,目前已经改成使用react-refresh来实现了。.../index.html' }), new ReactRefreshWebpackPlugin(), new VueLoaderPlugin() ], module: { rules...更绝望的是,网上百度不到为什么。图片我一度以为是版本问题,但是怎么处理都不像。还好最后参照了别人使用这个插件的代码,最后发现了问题。...webpack.config.jsmodule.exports = { mode: 'development' // 就是这里 ....}注:这个ReactRefreshWebpackPlugin进行打包的时候

95620
领券