我来自Objective-C背景。我必须以编程方式创建对象,因此尝试在Java和Kotlin中对其进行探索。
在Objective-C中,我们曾经在.h文件中声明实例变量并在.m文件中的任何位置访问它们,是否存在类似的接口,我们在某处声明变量和对象类型,然后在我们的kotlin类中对其进行访问?
我正在尝试声明一个变量,我可以在类内部的不同方法中对其进行访问(例如MainActivity)。在Java中,它工作正常,但是在Kotlin中,我想在不进行初始化的情况下很难声明它。需要帮助。
//Here is the Java Code that works fine.
public class MainActivity extends AppCompatActivity {
**LinearLayout box;**
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
**box = new LinearLayout(this);**
}
private void SampleMethod () {
**box.setBackgroundColor(Color.RED);**
}
}
如果我尝试在Kotlin中实现此目标,则会使用堆栈跟踪中提供的错误停止应用程序。
//Here is Kotlin code that is stopping the app.
class MainActivity : AppCompatActivity() {
**val sample = TextView(this)** // I need to declare variable here.
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
**sample.setText("Hello!")**
MainContainer.addView(sample)
}
fun Test() {
**sample.setBackgroundColor(Color.RED)**
}
}
这是Stacktrace
07-04 13:16:14.690 12663-12663/? I/zygote: Not late-enabling -Xcheck:jni (already on)
07-04 13:16:15.230 12663-12663/? W/zygote: Unexpected CPU variant for X86 using defaults: x86
07-04 13:16:16.639 12663-12663/com.example.sample.kotlinproject I/InstantRun: starting instant run server: is main process
07-04 13:16:16.938 12663-12663/com.example.sample.kotlinproject D/AndroidRuntime: Shutting down VM
07-04 13:16:16.940 12663-12663/com.example.sample.kotlinproject E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.sample.kotlinproject, PID: 12663
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.sample.kotlinproject/com.example.sample.kotlinproject.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.res.Resources android.content.Context.getResources()' on a null object reference
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2679)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2856)
at android.app.ActivityThread.-wrap11(Unknown Source:0)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1589)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:164)
at android.app.ActivityThread.main(ActivityThread.java:6494)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.res.Resources android.content.Context.getResources()' on a null object reference
at android.content.ContextWrapper.getResources(ContextWrapper.java:89)
at android.view.ContextThemeWrapper.getResourcesInternal(ContextThemeWrapper.java:127)
at android.view.ContextThemeWrapper.getResources(ContextThemeWrapper.java:121)
at android.support.v7.app.AppCompatActivity.getResources(AppCompatActivity.java:542)
at android.view.View.<init>(View.java:4563)
at android.view.View.<init>(View.java:4706)
at android.view.ViewGroup.<init>(ViewGroup.java:597)
at android.widget.LinearLayout.<init>(LinearLayout.java:234)
at android.widget.LinearLayout.<init>(LinearLayout.java:230)
at android.widget.LinearLayout.<init>(LinearLayout.java:226)
at android.widget.LinearLayout.<init>(LinearLayout.java:222)
at com.example.sample.kotlinproject.MainActivity.<init>(MainActivity.kt:18)
at java.lang.Class.newInstance(Native Method)
at android.app.Instrumentation.newActivity(Instrumentation.java:1174)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2669)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2856)
at android.app.ActivityThread.-wrap11(Unknown Source:0)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1589)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:164)
at android.app.ActivityThread.main(ActivityThread.java:6494)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
答案 0 :(得分:2)
class MainActivity : AppCompatActivity() {
val sample = TextView(this)
这行不通-您的Android书籍或教程应说明原因。使用构造函数实例化AppCompatActivity
来获取Activity
的完整实例是不够的。
通常,最好等到onCreate
之后再尝试以编程方式实例化视图。
class MainActivity : AppCompatActivity() {
lateinit var myTextView: TextView
override fun onCreate(savedInstanceState: Bundle) {
//instantiate myTextView here if you must
}
}