Java的学习(语法相关)

字符串存储的问题

char 和字符串都是字符的集合,它们之间的确有相似性,但在 Java 中它们有着不同的存储机制和处理方式。让我从 charString 的本质区别入手来解释。

1. charString 的区别

  • char 是基本类型char 是 Java 中的基本数据类型,用来存储单个字符,占用固定的内存空间(2 字节)。因为 char 是基本类型,所以它不存储在常量池或堆中,而是直接在栈上分配内存。

  • String 是对象String 是一个引用类型,本质上是字符数组的封装。字符串存储在堆内存中,并且不可变。

2. 常量与非常量的区别

  • 字符串常量:字面量字符串在 Java 中存储在字符串常量池中。只要内容相同,程序中多次使用相同的字符串字面量时,它们都会指向常量池中的同一个对象。

  • char 常量char 可以是常量(例如 'a'),也可以是变量,但它本质上是一个基本数据类型,不是对象。char 常量并没有像字符串那样的“常量池”机制。

3. 为什么 charAt() 不会创建新对象

当你使用 charAt() 获取字符串中的某个字符时,返回的只是一个基本类型的 char,不会涉及到对象的创建或字符串的拼接,因此不会像 substring() 那样在堆内存中创建新对象。

String str = "hello";
char ch = str.charAt(1); // 返回 'e'

这里的 charAt(1) 返回的是 'e',只是从字符串 str 中取出了这个字符,并没有创建新的对象,因为 char 是基本数据类型。

4. substring()charAt() 的不同

  • substring()substring() 方法截取字符串,创建新的字符串对象,并返回这个对象。即使你从一个常量字符串中截取了一部分,substring() 返回的结果仍然是一个新的字符串对象。

  • charAt()charAt() 返回的是一个 char 基本类型的值,而不是一个对象。由于 char 是基本类型,因此不会像字符串对象那样需要额外的内存分配和对象创建。

5. charString 常量的区别

  • char 常量:比如 'a',是基本类型,它的值直接存在栈上,不像字符串那样有常量池的概念。你可以在任何地方直接使用 char 常量,它不会像字符串一样占用大量内存。

  • String 常量:字符串常量存储在常量池中,允许多个引用指向相同的内存地址,节省内存空间。

6. 总结:为什么 charString 不一样

  • char 是一个基本数据类型,其值直接存储,不涉及对象创建。

  • String 是一个引用类型,是对象,涉及到对象的创建和内存管理。

  • charAt() 返回一个 char 值,它只是提取字符,不需要创建新的对象。

  • substring() 创建并返回的是一个新的字符串对象,即使它是从常量字符串中截取的。

因此,charString 的区别主要在于存储机制和数据类型的不同,这是 Java 为了性能和内存优化做出的设计。

常量字符串我也可以截取里面的部分,当做一个正常的常量字符串使用?

是的,常量字符串中的部分可以通过方法截取

 1.截取常量字符串的部分

当你使用 substring() 等方法从常量字符串中截取一部分时,如果这部分字符串是从一个编译期确定的常量字符串中截取的,并且符合常量表达式的规则,Java 编译器会将其视为一个新的常量字符串,并存储在常量池中。

String str = "hello world";
String subStr = str.substring(0, 5); // 截取 "hello"

在这种情况下,str 是一个常量字符串,subStr 也是从中截取的常量字符串。这里,编译器可能会将 subStr 优化为常量池中的字符串 "hello",而不创建新的对象。

2. 运行时截取和常量池

如果你是在运行时进行字符串截取(例如操作的不是编译时确定的字符串),那么 Java 会在堆内存中创建一个新的字符串对象,而不是将结果存储在常量池中。

String str1 = new String("hello world");
String subStr1 = str1.substring(0, 5); // 运行时创建一个新的字符串对象 "hello"

这里的 str1 是通过 new String() 创建的,在堆中分配内存,substring(0, 5) 会生成一个新的字符串对象并存储在堆中,不会进入常量池。

1. 字符串常量池的设计目的:优化性能和内存使用

Java 中的字符串常量池(String Pool)是为了优化内存使用。它的作用是避免在程序中创建重复的字符串对象。

  • 当你声明一个字符串字面量时,比如:

    String str1 = "hello";

  • String str2 = "hello";

    这两个字符串指向的是常量池中同一个字符串对象,不会重复创建。这种机制极大地减少了内存消耗,特别是在字符串频繁出现重复内容时。

  • 由于常量字符串是不可变的,同一个字面量字符串可以被多个引用共享而不产生问题。这就是常量池的作用:复用相同的字符串对象,减少内存的使用和垃圾回收的负担。

2. new String() 为什么要创建新的字符串对象?

new String() 会在堆内存中创建一个新的字符串对象,即使内容与常量池中的字符串相同。

  • 为什么需要 new String()?因为有时候你需要明确创建一个新的对象,而不是使用共享的常量池对象。比如,在某些特定场景下,程序可能需要对字符串对象的引用进行操作,不希望与其他引用共享相同的对象。

  • 堆内存中的对象可以被独立操作和管理,而常量池中的对象则是全局共享的,不能被修改(因为字符串是不可变的)。new String() 提供了一个创建全新对象的方式,避免了在某些场景下的意外副作用。

字符串拼接和内存

当涉及到字符串拼接时,Java 可能会创建新的字符串对象:

  • 如果拼接的是常量字符串,Java 会在编译时将它们合并为一个常量,并存储在常量池中,不会创建新的对象。

  • 如果拼接的是运行时动态生成的字符串,Java 会在堆内存中创建新的字符串对象。

  • String str1 = "hello";
    String str2 = new String(" world");
    String result = str1 + str2; // 运行时生成新的字符串对象
    

    在这种情况下,Java 会在堆中创建一个新的字符串 "hello world"

在 Java 中,无论是常量字符串还是通过 new String() 创建的字符串,当你使用 charAt() 获取某个字符时,不会创建新的字符串或字符对象charAt() 的结果是返回该字符串中指定位置的字符,而这个字符是基本数据类型 char,因此不会涉及到新建对象。

1. charAt() 的处理方式

1. 直接声明字符串常量

String str = "sadasd";

2. new String("asdasd") 创建新的字符串 

String str = new String("asdasd");

当你使用 new String("asdasd") 时,虽然 "asdasd" 是一个常量,并且会存储在字符串常量池中,但是 new String() 会在堆内存中再创建一个新的 String 对象。这意味着堆中和常量池中会存在两个不同的字符串对象,虽然它们的值相同,但它们是不同的对象。 

使用字符串常量下标获取字符

String str = "example";
char ch = str.charAt(2); // 获取下标为2的字符

在这里,charAt(2) 是从字符串常量中获取第 3 个字符,它并不会创建新的字符串或字符对象,而是直接从原有的字符串常量中取出对应的字符。 

常量字符串是由常量字符拼接起来的吗?

不完全是这样。常量字符串(字面量)本身存储在字符串常量池中,并不是由单个字符的拼接直接构成的。常量字符串在编译时已经是完整的字符串对象,而不是通过逐个字符拼接成的。

当你声明一个字符串字面量时,Java 会在编译阶段将它存储在字符串常量池中。即使你像下面这样拼接两个字符串常量,Java 也会在编译时优化为一个完整的常量字符串。

String str = "he" + "llo"; // 编译时优化为 "hello"

在这个例子中,"he""llo" 是常量,它们在编译时被合成为一个新的常量 "hello",并且直接存储在字符串常量池中。 

匿名内部类

类的访问修饰符

  1. public

    • 类可以被任何其他类访问。
    • 适用于需要在整个应用程序中被广泛使用的类。
  2. private

    • 仅能在定义该类的外部类(在嵌套类的情况下)访问。
    • 这样的类通常用于只在特定上下文中使用,其他类无法直接创建或使用它们。
  3. protected

    • 类可以被同一包中的其他类和任何继承该类的子类访问。
    • 适用于希望让子类访问的类,但不希望其他类直接使用的情况。
  4. internal(C# 特有):

    • 类只能在同一程序集内访问。
    • 适用于希望限制访问到特定程序集的类。
  5. 默认(无修饰符)(Java 特有):

    • 类在同一包中可见,其他包中的类无法访问。
    • 用于在包内部共享类,但不想对外部可见。

c#里

  • 如果不显式指定访问修饰符,类和接口的默认访问级别都是 internal
  • 要让它们在整个应用程序中可见,您需要显式地将它们声明为 public

在 Java 中,类和接口的默认访问修饰符是“包私有”(package-private),即如果没有显式指定访问修饰符,类和接口只能在同一包内被访问。

接口

C# 中,接口的只读属性是实例成员,每个实现这个接口的类可以独立实现该属性,并返回不同的值。

java里则严格要求,不能让实现类里有接口带来的实例属性,实现类只能使用接口中的常量,而不能修改它们。

public interface MyInterface {int CONSTANT_VALUE = 100; // 必须赋值,且是 public static final
}
c#中
  • 接口中只能定义方法的签名,不能包含实现。
  • 接口中的方法默认是 public,且不能使用其他访问修饰符。

在 C# 中,接口中的成员(包括方法、属性、事件等)默认是 public。如果你没有显式地指定访问修饰符,编译器会将它们视为 public。例如:

public interface IMyInterface
{void MyMethod(); // 默认是 public
}
public interface IMyInterface
{void MyMethod();void DefaultMethod(){// 默认实现}
}

常量定义:在 Java 中,你可以定义常量,默认为 public static final。而在 C# 中,接口不允许定义字段或常量,但可以定义只读属性。

关于常量

接口这个东西,可以设置static常量附着在该接口类上,在接口中写的所有,都为public,public为接口特色,

在c#,可以定义只读属性,附着在该接口类上,java里,则是可以定义static final int 常量,通过该方式定义常量

在 Java 中,接口中定义的常量是 public static final 的,必须在接口中赋值,不能在实现类中重新赋值。

java

Java 8,引入了默认方法和静态方法的实现。

属性

  • 接口中可以定义常量(static final),但不能定义实例变量。常量必须是 public static final,通常省略修饰符:
  • public interface MyInterface {void doSomething();default void doDefault() {// 默认实现}
    }public interface MyInterface {int MY_CONSTANT = 10; // 默认是 public static final
    }public interface MyInterface {static void myStaticMethod() {// 静态方法实现}
    }
    

实现接口的类必须提供所有方法的实现(除非类是抽象类)

public class MyClass implements MyInterface {@Overridepublic void doSomething() {// 实现代码}
}
 总结

总结一下,所有的接口,全是public是一大特征,

然后在java里,接口更加独立于实现类,对于常量,都static final属于接口且必须赋值,

而在C#里,对于常量,有非静态只读属性,可以只在接口里声明,然后在各个不同的实现类里各自设置只读属性值,

对于方法,两者都可以只定义,也可以在接口里预先实现,并可在实现类中重写

构造器

java的访问修饰符

子类继承之后,父类的私有只是不能访问而已,可是依然存在,

子类不能继承父类的私有成员,意思是子类会开一块区域,父类也开一块区域,两个所处内存位置不同,但因为继承的关系,子类可以调用父类内存区域的方法

父类的数据存储在子类对象的内存中,子类只是不能直接访问父类的 private 成员而已。

这是因为子类对象不仅包含子类自己的成员,还包含父类的成员——无论是 privateprotected 还是 public 成员,尽管 private 成员只能在父类内部访问。

子类只能继承父类的非私有成员

父类中的私有成员和方法不能被子类继承

父类中的私有也不能被子类重写

java的static

Java中,可以使用类对象来访问静态变量,但实际上这是不推荐的

C#中,静态变量必须通过类名来访问,不能通过对象来访问

c的static相关补充

c中的静态变量是属于定义的函数的,只不过是全局存在的

如果在外部定义,和直接定义的变量不同的是,静态变量只限于本文件内可以用,

  • static局部变量:生命周期是整个程序运行期间,但作用域限制在函数内
  • static全局变量:作用域限制在当前源文件,生命周期是整个程序。
  • static全局变量:可以被整个程序中的其他源文件引用

假设有两个文件:file1.cfile2.c

  • file1.c 中定义一个全局变量。
  • file2.c 中使用 extern 关键字来声明该全局变量,这样就可以在 file2.c 中访问和修改 file1.c 中的全局变量
  • 文件1: file1.c
    #include <stdio.h>int sharedVariable = 42;  // 定义全局变量void modifyVariable() {sharedVariable++;  // 修改全局变量printf("In file1.c, sharedVariable = %d\n", sharedVariable);
    }
    ---------------------------------------------------------------------
    文件2: file2.c
    #include <stdio.h>extern int sharedVariable;  // 声明 file1.c 中的全局变量void printVariable() {printf("In file2.c, sharedVariable = %d\n", sharedVariable);
    }int main() {printVariable();   // 输出 file1.c 中的 sharedVariable 值sharedVariable += 10;  // 修改该变量printVariable();   // 输出修改后的 sharedVariable 值return 0;
    }
    

    使用 extern 引用其他文件中的变量时,变量名必须与定义时保持一致。这是因为 C 语言在编译和链接时,依赖变量的名称来关联不同源文件中的全局变量。

  • 例如,在文件 file1.c 中定义了全局变量 int a;,那么在 file2.c 中,使用 extern 时必须写作 extern int a;,这样才能正确引用到 file1.c 中的变量 a

  • 如果没有使用 static 修饰符全局变量在同一个程序的不同源文件中不能重名,否则会导致重定义错误。编译器在链接阶段会报错,因为它发现同名的全局变量在不同文件中有多个定义。

  • 如果你希望在不同文件中使用同名的全局变量,就用 static 修饰符将变量的作用域限制在各自的文件内,这样即使同名变量在不同文件中定义,它们也不会冲突。static 关键字会将变量的作用域限制在定义它的文件中,从而避免冲突。

Java中,类中的成员变量(也称为字段)默认并不是private

访问修饰符的默认行为:

  • private: 变量只能在类的内部访问。
  • default(没有修饰符): 变量只能在同一个包内的类中访问。
  • protected: 变量可以在同一个包内,或者在其他包中的子类中访问。
  • public: 变量可以在任何地方访问。

ASCII 表中

ASCII 表中,大小写字母并不是紧密相连的

大写字母 (AZ) 对应的码值是 65 到 90

中间的 91 到 96

  • 91: [
  • 92: \
  • 93: ]
  • 94: ^
  • 95: _
  • 96: `

小写字母 (az) 对应的码值是 97 到 122。

java输出

随机数的生成

 Math.random生成0到1之间的随机小数

Random r=new Random();//生成一个随机数对象

通过r.nextInt(int整数);生成0到int数之间的随机一个数

注:绝大多数的随机数都是包前不包后

enum

Java 不允许将整数直接赋给 enum 类型变量。你必须使用 enum 类型定义的常量。

不允许 enum 类型通过整型强制转换

Color myColor = Color.RED; // 正确
// Color myColor = 0; // 编译错误

C# 不能直接整数赋值,如果要赋值要强制转换。

Color myColor = (Color)0; // 强制转换
// Color myColor = 0; // 编译错误

 C和C++可以直接整数赋值

C#和C和C++都可以给枚举赋超出范围的整数值,该枚举变量会记住这个值,

只不过表现的更像一个数而不是枚举

switch

java

C#也一样不能用float,double,long 

c和c++本质是把switch当做整数接受器,enum只是另外一种整型的表现方式,所以,c的switch传入的enum要强转回整数,c++虽然优化了不用强转回整数接受,但本质上还是接受整数

而java和c#则是把switch当做类型接受器,传入的类型一定要和case标签类型相同,不同的是,在enum的传入上,java必须传入enum类型不能用整数强转,而c#支持整数的强转成对应的enum

Java 的 switch 语句支持的类型有:

  • byte
  • short
  • char
  • int
  • enum(从 Java 5 开始)
  • String(从 Java 7 开始)
  • var(Java 12 中的增强型 switch 表达式)

C# 中的 switch 语句支持的类型类似于 Java,包括:

  • char
  • string
  • bool
  • enum
  • 整型类型(intbyteshort 等)
  • C# 7 之后,支持模式匹配(switch 表达式的增强)

在所有语言中,switch 不会自动进行类型转换,类型必须严格匹配。

都不支持float和double作为case标签的数据类型

c#和java:支持整数、枚举、字符串等类型作为 switch 表达式和 case 标签

c和c++:只支持整数和枚举

枚举类型在C和C++中有所不同。在C语言中,枚举类型(enum)虽然本质上是整数,但不能直接用于switch语句中必须通过强制类型转换将枚举值转换为整数类型

#include <stdio.h>enum Color {RED,    // 默认值为 0GREEN,  // 默认值为 1BLUE    // 默认值为 2
};int main() {enum Color myColor = 0; // 设置为 0,相当于 RED/*在c++中Color myColor = GREEN;或者Color myColor = static_cast<Color>(0);//设置为RED也可以将整数值 0 直接赋给 enum 类型的变量Color mycolor=0;    *///c++仅仅是优化了不用强转int的操作,本质上仍与c相同switch (1) {//会进入GREEN//这与在c++中相同case RED:printf("Color is RED\n");break;case GREEN:printf("Color is GREEN\n");break;case BLUE:printf("Color is BLUE\n");break;default:printf("Unknown color\n");break;}return 0;
}

&, |, ^

C, C++, Java, C# 等语言中,按位运算符(&, |, ^)遵循类型提升规则

  1. 整数类型提升:如果操作数是小于 int 的类型(如 char, short 等),它们会先提升为 int
  2. 如果操作数有不同的宽度(比如一个是 int,另一个是 long),较窄的类型会被提升为较宽的类型。
  3. 如果一个操作数是有符号类型,另一个是无符号类型,通常会将有符号类型提升为无符号类型(具体规则依赖于语言的实现)。
  4. 位运算直接操作的是数据的二进制位,所以只能用于整数类型。

都可以进行位运算

int a = 5;  // 0101
int b = 3;  // 0011
int result = a & b; // 0001, result is 1
int result = a | b; // 0111, result is 7
int result = a ^ b; // 0110, result is 6

C#Java 类似,&| 额外可以判断bool运算,但不具备短路特性。如果需要短路逻辑运算,C# 使用 &&||

CC++ 中,&, |, ^ 只能作为按位运算符,它们对整数的每一位进行操作,不能用于逻辑运算。逻辑运算必须使用 &&(逻辑与)和 ||(逻辑或)。

比较运算符

关系运算符比较,如果两边的类型不一样也会转成最高类型再比较

int a = 5;
double b = 5.5;
boolean result = a < b; // a 被提升为 double 进行比较

是的,在大多数编程语言中,关系运算符(如 <, >, <=, >=, ==, !=)比较时,如果两边的类型不同,会先进行类型转换,然后再进行比较。这个过程叫做类型提升(type promotion),通常会将较低精度的类型转换为较高精度的类型。

在 Java 中,不同类型之间进行关系运算时,会遵循自动类型提升的规则:

  • 如果一个操作数是 byte, short, char,则它们会先提升为 int 类型。
  • 如果一个操作数是 int 而另一个是 long,则 int 会被提升为 long
  • 如果一个操作数是 float 而另一个是 double,则 float 会被提升为 double
  • 数值类型(如 int, long, float, double)会根据两边的最大类型进行提升。

在 C# 中,类似的规则也适用:

  • 如果两边类型不同,较小的类型将提升为较大的类型,以进行比较。
  • int 会被提升为 longfloat 会被提升为 double,等等。

C 和 C++ 中,类型提升也是相似的:

  • char, short 等会被提升为 int
  • int 会提升为 longfloatdouble 等更高精度的类型。
  • 如果一个操作数是 float,另一个是 double,则 float 会被提升为 double

+运算符

从前往后算,能相加优先相加,不能相加则拼接

char是可以转成数相加的,在没有拼接需求之前,char都可以看做数去相加

java的Scanner输入

(需要先导包)import java.util.Scanner

Scanner scanner = new Scanner(System.in);

常用方法:

  • next(): 读取下一个以空格或换行分隔的字符串。
  • nextLine(): 读取一整行输入,直到遇到换行符
  • nextInt(): 读取下一个整数。
  • nextDouble(): 读取下一个浮点数。
  • hasNext(), hasNextInt(), hasNextDouble(): 用于检测是否有下一个可读取的输入数据。

注意事项:

  • 输入不匹配:当用户输入与预期的数据类型不匹配时,可能会抛出 InputMismatchException。例如,调用 nextInt() 时输入了一个字符串。
  • 资源管理:在读取输入完成后,建议调用 scanner.close() 关闭 Scanner,防止资源泄露。

通过创建Scanner类的对象,调用对象的next方法

字面量,字面上的量

一个方法中,该方法名和其中的变量名可以相同

API为什么叫API

API(应用程序接口,Application Programming Interface)

规范化的交互方式

面向对象编程中的接口是你必须实现的,而 API 是你直接使用的。

但两者的相似点在于:它们都提供了一组明确的规则和方法来与其他代码或系统进行交互。

List<String> list = new ArrayList<>();
list.add("Hello");

这里的 ArrayList 是一个现成的类,add 方法是它提供的 API。你无需知道它内部如何实现,只需调用它提供的功能(当然,arraylist也是API)

一组可以让不同软件组件或系统之间进行交互的定义和协议

提供现成的功能供开发者使用,不是为了让你去实现,而是为了调用,从而完成特定任务。

API 可能包括库、函数、类、或者在线服务的调用

自动类型转换

扩展运算符自带强转自身类型(适用多种语言c,c++,c#)

int a = 5;
double b = 2.5;
a += b;  // a = (int)(a + b),结果是 7

在这个例子中,aintbdouble,在 a += b 中:

  • a + b先转换为 double 类型(因为 double 是更高精度的类型)
  • 结果是 7.5,然后由于 aint,最终的结果会被强制转换为 int,舍弃小数部分,变为 7

结果最终一定会匹配左侧变量的类型 

 在java中,如果想byte之间相加,不用扩展赋值运算符,赋值给byte时必须强转,因为相加时默认都转为int了,必须转回来否则报错,在c#也相同

Java 和 C#: byte (char类型也一样)类型相加结果会提升为 int,必须显式 强制转换回 byte(或者char)  

char a = 'A'; // Unicode 65
char b = 'B'; // Unicode 66
int sum = a + b; // sum 是 int 类型
char result = (char) (a + b); // 需要强制转换回 char

java和C#中char和int并不一体,而c++和c中char和int似乎可以一体 

C 和 C++

  • char 可以作为整数类型:在 CC++ 中,char 实际上是一个整数类型,通常占用 8 位(signedunsigned)。char 类型的变量在算术运算中可以与 int 类型互换,因此可以直接进行算术运算而不需要显式转换。
  • char a = 'A'; // ASCII 65
    char b = 'B'; // ASCII 66
    int sum = a + b; // sum 是 int 类型
    char result = a + b; // 结果会被隐式转换为 char,但可能会有溢出

但扩展赋值运算符,这些语言都一样,会最后进行强转

表达式中运算,小范围byte,short,char,优先转为int后,再开始判断运算

即使是byte+byte也会得到int

double在float之上,而float在long之上

结果取决于整个运算表达式的最高类型,无论顺序

int a = 5;
double b = 2.0;
double result = a / b;  // 结果为 2.5
  • C#Java 的自动类型转换大体相似,都能隐式地从较小范围类型转换为较大范围类型。
  • C# 支持用户自定义的隐式和显式转换(implicitexplicit 关键字,而 Java 不允许用户定义类型转换。
  • //隐式转换
    class Celsius
    {public double Degrees { get; set; }public static implicit operator Celsius(double d){return new Celsius { Degrees = d };}
    }Celsius temp = 36.5;  // 隐式转换
  • 泛型协变与逆变C# 特有的功能,而 Java 使用通配符来实现类似功能。
  • 装箱和拆箱 在两者中都存在,但 Java 的自动装箱/拆箱机制更加简便。

PATH

  • PATH 变量操作系统的环境变量之一,包含了一系列目录路径,操作系统在运行程序时会在这些目录中查找可执行文件。
  • 例如,当你在命令行中输入 javajavac,操作系统会在 PATH 变量中列出的目录中查找这些命令的可执行文件。

bin

bin 文件夹:Java Development Kit (JDK) 安装目录下的 bin 文件夹包含了 Java 编译器(javac)、Java 运行时环境(java)等命令行工具。

添加到 PATH:将 bin 文件夹添加到 PATH 变量中,可以让你在任何命令行窗口中直接运行 Java 相关的命令,而不需要每次都导航到 JDK 的安装目录。

验证设置

  • 打开命令提示符(cmd),输入 java -versionjavac -version,检查是否能正确输出 Java 版本信息。

更新上下文菜单

上下文菜单 是指在操作系统的文件资源管理器中,右键点击文件或文件夹时弹出的菜单。这个选项的作用是将一些功能(如打开特定文件类型的 IDE)添加到文件的右键菜单中。

  • 作用:通过选择"更新上下文菜单",你可以将 IntelliJ IDEA(或其他工具)集成到操作系统的上下文菜单中。例如,你可以右键点击一个 .java 文件,然后选择“用 IntelliJ IDEA 打开”来快速启动 IDE 并打开该文件。
  • 方便性:这使得文件和项目的管理更加便捷,尤其是在处理多个文件时。

创建关联

文件关联 指的是将特定文件类型与一个程序关联,使得在打开该文件时,操作系统会默认使用这个程序。

  • 作用:选择"创建关联"可以将 IntelliJ IDEA 设置为打开特定类型文件的默认应用。例如,你可以将 .java.xml.html 文件与 IntelliJ IDEA 关联,这样双击这些文件时会自动用 IntelliJ IDEA 打开。
  • 方便性:这种关联使得文件打开变得更加高效,无需每次都手动选择程序来打开文件。

更新上下文菜单:将 IDE 或其他工具添加到文件资源管理器的右键菜单中,方便快速打开文件。

创建关联:将特定类型的文件与 IDE 关联,使得打开这些文件时自动使用 IDE。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/54256.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C++】多态(下)

个人主页~ 多态&#xff08;上&#xff09;~ 多态 四、多态的原理1、虚表的存储位置2、多态的原理3、动态绑定和静态绑定 五、单继承和多继承关系的虚函数表1、单继承中的虚函数表2、多继承中的虚函数表 六、多态中的一些小tips 四、多态的原理 1、虚表的存储位置 class A {…

CORE MVC 过滤器 (筛选器)

MVC FrameWork MVCFramework MVC Core 过滤器 分 同步、异步 1、 授权筛选器 IAuthorizationFilter&#xff0c;IAsyncAuthorizationFilter 管道中运行的第一类筛选器&#xff0c;用来确定发出请求的用户是否有权限发出当前请求 2、资源筛选器 IResourceFilter &#xff0c;…

微软准备了 Windows 11 24H2 ISO “OOBE/BypassNRO“命令依然可用

Windows 11 24H2 可能在未来几周内开始推出。 微软已经要求 OEM 遵循新的指南准备好 Windows 11 24H2 就绪的驱动程序&#xff0c;并且现在已经开始准备媒体文件 (.ISO)。 OEM ISO 的链接已在微软服务器上发布。 一个标有"X23-81971_26100.1742.240906-0331.ge_release_sv…

Vue3项目开发——新闻发布管理系统(九)(完结篇)

文章目录 十一、用户信息管理1、用户基本资料管理1.1 页面设计1.2 封装接口,更新信息2、更换头像2.1 静态结构2.2 选择图片预览2.3 上传头像3、重置密码3.1 页面设计3.2 封装接口,更新密码十二、项目打包十三、系统全部源码下载十一、用户信息管理 用户信息管理包括功能:基…

第四届机器人、自动化与智能控制国际会议(ICRAIC 2024)征稿

第四届机器人、自动化与智能控制国际会议&#xff08;ICRAIC 2024&#xff09;由湖南第一师范学院主办&#xff0c;南京师范大学、山东女子学院、爱迩思出版社&#xff08;ELSP&#xff09;协办。 大会将专注于机器人、数字化、自动化、人工智能等技术的开发和融合&#xff0c…

如何让 Android 的前端页面像 iOS 一样“优雅”?

作者:方英杰&#xff08;崇之&#xff09; 最近在调研前端页面适配 Android 端异形屏的方案&#xff0c;调研过程中发现了一些比较有意思的点&#xff0c;本文主要是做一个总结。 一、提出问题 首先&#xff0c;我们需要知道 Android 上的前端适配面临着什么问题。 问题其实很…

【含文档】基于Springboot+Vue的停车场车位预约系统(含源码+数据库+lw)

1.开发环境 开发系统:Windows10/11 架构模式:MVC/前后端分离 JDK版本: Java JDK1.8 开发工具:IDEA 数据库版本: mysql5.7或8.0 数据库可视化工具: navicat 服务器: SpringBoot自带 apache tomcat 主要技术: Java,Springboot,mybatis,mysql,vue 2.视频演示地址 3.功能 系统定…

ICPC-day1(NTT)

NTT经典例题 CCPC-Winter-Camp-day6-A——NTT经典例题 对于上面格式&#xff0c;如果想求出每个i的值可以使用卷积求出&#xff0c;因为阶乘j和阶乘i-j相乘的值为(i(i-j))i 补充一个二次剩余定理 P5491 【模板】二次剩余 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) //#in…

基于工业物联网的能源监控系统:边缘数据处理的应用

论文标题&#xff1a;《Industrial IoT-Based Energy Monitoring System: Using Data Processing at Edge》 作者信息&#xff1a; Akseer Ali MiraniAnshul AwasthiNiall O’MahonyJoseph Walsh 他们均来自爱尔兰的芒斯特技术大学IMaR研究中心&#xff0c;以及位于利默里克的…

JVM 基础、GC 算法与 JProfiler 监控工具详解

目录 1、引言 1.1 JVM内存与本地内存 1.2 JVM与JDK的关系 2、JVM基础 2.1 JVM&#xff08;Java Virtual Machine&#xff09; 2.2 Java与JVM的关系 2.3 JVM的内存结构 2.3.1 堆内存 2.3.2 栈内存 2.3.3 方法区 2.3.4 本地方法栈 2.3.5 程序计数器&#xff08;PC寄存…

【MySQL 07】内置函数

目录 1.日期函数 日期函数使用场景&#xff1a; 2.字符串函数 字符串函数使用场景&#xff1a; 3.数学函数 4.控制流函数 1.日期函数 函数示例&#xff1a; 1.在日期的基础上加日期 在该日期下&#xff0c;加上10天。 2.在日期的基础上减去时间 在该日期下减去2天 3.计算两…

Android Context是什么?有很多的context他们之间有什么区别?什么时候该使用哪个?

目录 一、Context是什么&#xff1f; 在Android中&#xff0c;Context是一个抽象类 &#xff0c;它代表了应用程序的当前状态&#xff0c;包括资源和类加载器等&#xff0c;它提供了一个应用运行所需的信息&#xff0c;比如我们要获取资源 &#xff0c;那么需要她&#xff0c;…

雷池 WAF 如何配置才能正确获取到源 IP

经常有大哥反馈说雷池攻击日志里显示的 IP 有问题。 这里我来讲一下为什么一些情况下雷池显示的攻击 IP 会有问题。 问题说明 默认情况下&#xff0c;雷池会通过 HTTP 连接的 Socket 套接字读取客户端 IP。在雷池作为最外层网管设备的时候这没有问题&#xff0c;雷池获取到的…

【寻找one piece的算法之路】——双指针算法!他与她是否会相遇呢?

&#x1f490;个人主页&#xff1a;初晴~ &#x1f4da;相关专栏&#xff1a;寻找one piece的刷题之路 什么是双指针算法 双指针算法是一种常用的编程技巧&#xff0c;尤其在处理数组和字符串问题时非常有效。这种方法的核心思想是使用两个指针来遍历数据结构&#xff0c;这两…

【HTML+CSS】仿电子美学打造响应式留言板

创建一个响应式的留言板 在这篇文章中&#xff0c;我们将学习如何创建一个简单而美观的留言板&#xff0c;它将包括基本的样式和动画效果&#xff0c;以及响应式设计&#xff0c;确保在不同设备上都能良好显示。 HTML 结构 首先&#xff0c;我们创建基本的HTML结构。留言板由…

Android SQLite的基本使用、生成Excel文件保存到本地

1. Android SQLite的基本使用 1.1. SQLiteOpenHelper Android 底层已经通过一个SQLiteOpenHelper的抽象类将数据库的创建&#xff0c;以及修改&#xff0c;更新等都放在了里面。 要使用它必须实现它的OnCreate(SQLiteDatabase db)&#xff0c;onUpgrade(SQLiteDatabase db, int…

YOLOv11改进 | 独家创新- 注意力篇 | YOLOv11结合全新多尺度线性注意力机制MLAttention(全网独家创新)

1. MLAttention介绍 (1). 多尺度卷积操作&#xff1a;MLAttention通过多尺度卷积操作来增强不同尺度的特征表达能力。采用了多种卷积核尺寸&#xff08;例如5x5、1x7、7x1、1x11、11x1、1x21、21x1&#xff09;的深度可分离卷积来捕捉不同感受野的特征。较小的卷积核擅长捕捉细…

TypeScript 算法手册【快速排序】

文章目录 1. 快速排序简介1.1 快速排序定义1.2 快速排序特点 2. 快速排序步骤过程拆解2.1 选择基准元素2.2 划分数组2.3 递归排序 3. 快速排序的优化3.1 三数取中法选择基准3.2 插入排序与快速排序结合案例代码和动态图 4. 快速排序的优点5. 快速排序的缺点总结 【 已更新完 Ty…

C语言基础(7)之操作符(1)(详细介绍)

目录 1. 各种操作符介绍 1.1 操作符汇总表 2. 移位操作符 2.1 移位操作符知识拓展 —— 原码、反码、补码 2.2 移位操作符讲解 2.2.1 右移操作符 ( >> ) 2.2.2 左移操作符 ( << ) 3. 位操作符 3.1 & (按位与) 3.2 | (按位或) 3.3 ^ (按位异或) 3.4…

排序算法之——归并排序,计数排序

文章目录 前言一、归并排序1. 归并排序的思想2. 归并排序时间复杂度及空间复杂度3. 归并排序代码实现1&#xff09;递归版本2&#xff09;非递归版本 二、计数排序1. 计数排序的思想2. 计数排序的时间复杂度及空间复杂度3. 计数排序代码实现 总结&#xff08;排序算法稳定性&am…