sth for class.forname

本文探讨了JVM如何加载类及执行静态代码段,并对比了newInstance()方法与new关键字在对象创建上的不同之处。此外,还介绍了这两种方法在软件设计中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

jvm会执行静态代码段,静态代码是和class绑定的,class装载成功就表示执行了你的静态代码了,而且以后不会再走这段静态代码了。

Class.forName(xxx.xx.xx) 返回的是一个类 
Class.forName(xxx.xx.xx);
的作用是要求JVM查找并加载指定的类,也就是说JVM会执行该类的静态代码段

在初始化一个类,生成一个实例的时候,newInstance()方法和new关键字除了一个是方法,一个是关键字外,最主要有什么区别?它们的区别在于创建对象的方式不一样,前者是使用类加载机制,后者是创建一个新类。那么为什么会有两种创建对象方式?这主要考虑到软件的可伸缩、可扩展和可重用 等软件设计思想。 

Java中工厂模式经常使用newInstance()方法来创建对象,因此从为什么要使用工厂模式上可以找到具体答案。 例如: 
class c = Class.forName(“Example”); 
factory = (ExampleInterface)c.newInstance(); 

其中ExampleInterfaceExample的接口,可以写成如下形式: 
String className = "Example"; 
class c = Class.forName(className); 
factory = (ExampleInterface)c.newInstance(); 

进一步可以写成如下形式: 
String className = readfromXMlConfig;//
xml 配置文件中获得字符串 
class c = Class.forName(className); 
factory = (ExampleInterface)c.newInstance(); 

JVM的角度看,我们使用关键字new创建一个类的时候,这个类可以没有被加载。但是使用newInstance()方法的时候,就必须保证:1、这个 类已经加载;2、这个类已经连接了。而完成上面两个步骤的正是Class的静态方法forName()所完成的,这个静态方法调用了启动类加载器,即加载 java API的那个加载器。 

现在可以看出,newInstance()实际上是把new这个方式分解为两步,即首先调用Class加载方法加载某个类,然后实例化。 这样分步的好处是显而易见的。我们可以在调用class的静态加载方法forName时获得更好的灵活性,提供给了一种降耦的手段。 

最后用最简单的描述来区分new关键字和newInstance()方法的区别: 
newInstance: 
弱类型。低效率。只能调用无参构造。 
new: 
强类型。相对高效。能调用任何public构造。

 

Class clazz = cl.loadClass("XXX.XXX");没有指定是否初始化的选项。只有执行clazz.newInstance();时才能够初始化类。可以说Class.forName("XXX.XXX", false, cl)执行过程是一致的。只是ClassLoader.loadClass()是更底层的操作。

 

My conclusion : Class.forname()是装载一个类,并且初始化static,然后才可以newInstance()

它调用了ClassLoader.loadClass() ,该函数有个参数,设为true的话,初始化static,反之不初始化。

import os import csv import ast import os import csv import ast import time import ffmpeg from pandas import DataFrame class danmaku(): def init(self, csv_dir: str, videos: str, keywords: list, save: str, delete): self.csv_dir: str = csv_dir self.videos_path = videos self.keywords: list = keywords self.delete: bool = ast.literal_eval(delete) timeYMDHMS = time.strftime(“%Y%m%d_%H%M%S”, time.localtime(None)) self.save: str = os.path.join(save, timeYMDHMS) if not os.path.exists(self.save): os.mkdir(self.save) def search(self) -> list: ''' 对csv文件进行处理 仅保存有关键字的内容 ''' dan_data = [] dan_name = [] files = os.listdir(self.csv_dir) for file in files: if file.endswith(".csv"): da = [] f = os.path.join(self.csv_dir,file) with open(f,'r',encoding='utf-8') as f: read = csv.reader(f) read = list(read) read.pop(0) for data in read: if any(key in data[1] for key in self.keywords): # 判断每一条弹幕中是否存在任一关键字 da.append(data) if da: # 如果da不为空,即有包含关键字的内容 dan_data.append(da) dan_name.append(file.split('.')[0].split('_')[0]) return [dan_data,dan_name] def split_video(self, data: list, videos: list): ''' 根据有效弹幕分割视频 ''' for i in range(len(videos)): da = sorted(data[i], key=lambda x: float(x[0])) video = os.path.join(self.videos_path, videos[i]+".mp4") start = da[0][0] for temp in da: if temp != da[0]: end = temp[0] out = os.path.join(self.save, start+".mp4") ffmpeg.input(video, ss=start, t=end).output(out,c='copy').run() start = end print('ok') def run(self): data: list = self.search() if self.delete: self.split_video(data[0], data[1])报错 File "d:\sth_task_code\task4\danmaku.py", line 54, in split_video ffmpeg.input(video, ss=start, t=end).output(out,c='copy').run() AttributeError: module ‘ffmpeg’ has no attribute 'input’如何解决
最新发布
03-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值